@charset "UTF-8";

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

html, body { height: 100%; }

body {
  margin: 0;
  color: #333;
  background: #fff;
  font-family: "Zen Maru Gothic", sans-serif;
  font-weight: 500;
}

img {
  max-width: 100%;
  height: auto;
  vertical-align: bottom;
}

a { color: inherit; }

/* Header
========================================================= */
.header {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 110px;
  z-index: 1000;
  background: rgba(255, 255, 255, 0.75);
  backdrop-filter: blur(6px);
}

.header__inner {
  max-width: 1440px;
  height: 100%;
  margin: 0 auto;
  padding: 0 60px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 32px;
}

.header__logo {
  display: inline-flex;
  align-items: center;
  text-decoration: none;
  flex: 0 0 auto;
}

.header__logo-img {
  display: block;
  width: auto;
  height: auto;
}

.header__logo-img--pc { height: 64px; width: auto; }
.header__logo-img--sp { display: none; }

.header__nav {
  flex: 1 1 auto;
  display: flex;
  justify-content: center;
}

.header__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  gap: 28px;
  align-items: center;
}

.header__list a {
  font-family: "Zen Maru Gothic", sans-serif;
  font-weight: 500;
  font-size: 16px;
  color: #4A5D73;
  text-decoration: none;
  white-space: nowrap;
}

.header__list a:hover { opacity: 0.75; }

.header__cta {
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  text-decoration: none;
}

.header__cta img {
  width: 180px;
  height: auto;
  display: block;
  filter: contrast(1.08) saturate(1.05);
}

.header__menu {
  display: none;
  border: none;
  background: transparent;
  padding: 0;
  cursor: pointer;
}

.header__menu img {
  width: 24px;
  height: 24px;
  display: block;
}

/* SP Nav / Overlay（PCでは非表示）
========================================================= */
#spOverlay,
#spNav { display: none; }

/* FV
========================================================= */
.fv {
  position: relative;
  width: 100%;
  height: 640px;
  margin-top: 110px;
  overflow: hidden;
}

.fv__photo {
  position: absolute;
  inset: 0;
  z-index: 0;
}

.fv__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  opacity: 0;
  filter: blur(10px);
  transform: scale(1.03);
  animation: fvPhoto 1.2s ease-out forwards;
}

.fv::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  background: linear-gradient(
    90deg,
    rgba(250, 248, 245, 0.88) 0%,
    rgba(250, 248, 245, 0.45) 35%,
    rgba(250, 248, 245, 0.00) 65%
  );
}

.fv__copy {
  position: absolute;
  z-index: 2;
  left: 170px;
  top: 245px;
  max-width: 620px;
  text-align: left;
}

.fv__copy-inner {
  opacity: 0;
  filter: blur(8px);
  transform: translateX(-14px);
  animation: fvText 0.9s ease-out forwards;
  animation-delay: 0.75s;
}

.fv__sub {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 10px;
  margin-bottom: 30px;
}

.fv__sub-logo {
  width: 220px;
  height: auto;
  display: block;
  margin-left: -0.55em;
}

.fv__sub-text {
  display: block;
  font-family: "Zen Maru Gothic", sans-serif;
  font-weight: 500;
  font-size: 15px;
  letter-spacing: 0.30em;
  padding-left: 0.55em;
  color: rgba(74, 93, 115, 0.95);
}

.fv__title {
  margin: 0;
  font-family: "Shippori Mincho", serif;
  font-weight: 400;
  font-size: 56px;
  line-height: 1.22;
  letter-spacing: 0.18em;
  color: #4A5D73;
}

.fv__title-line { display: block; white-space: nowrap; }
.fv__title-line--second { margin-top: 18px; }

@keyframes fvPhoto {
  from { opacity: 0; filter: blur(10px); transform: scale(1.03); }
  to   { opacity: 1; filter: blur(0);    transform: scale(1); }
}

@keyframes fvText {
  from { opacity: 0; filter: blur(8px); transform: translateX(-14px); }
  to   { opacity: 1; filter: blur(0);   transform: translateX(0); }
}

/* About
========================================================= */
.about {
  position: relative;
  background: #fbf7f4;
  overflow: hidden;
  padding: 120px 40px 100px;
}

.about__inner {
  position: relative;
  width: min(1000px, 100%);
  margin: 0 auto;
  text-align: center;
}

.about__title {
  font-family: "Shippori Mincho", serif;
  font-size: 40px;
  font-weight: 500;
  letter-spacing: 0.10em;
  color: #3b4558;
  margin: 0 0 36px;
}

.about__copy {
  max-width: 680px;
  margin: 0 auto 44px;
  font-family: "Zen Maru Gothic", sans-serif;
  font-size: 16px;
  font-weight: 400;
  line-height: 2.6;
  letter-spacing: 0.08em;
  color: rgba(59, 69, 88, 0.72);
}

.about__copy p { margin: 0; }

.about__btn {
  display: inline-block;
  margin: 0 auto 64px;
  text-decoration: none;
}

.about__btn img {
  display: block;
  width: 360px;
  height: auto;
}

.about__grad {
  position: absolute;
  top: -48px;
  right: -96px;
  width: 560px;
  height: auto;
  pointer-events: none;
  opacity: 0;
  transform: scale(1.03);
  filter: blur(10px) saturate(0.9);
  will-change: opacity, transform, filter;
}

.about.is-inview .about__grad {
  opacity: 1;
  transform: scale(1);
  filter: blur(0) saturate(1);
  transition: opacity 1100ms ease, transform 1100ms ease, filter 1400ms ease;
}

/* About マーキー（PC）
========================================================= */
@media (min-width: 641px) {
  .about__images--marquee {
    width: 100vw;
    margin: 0 calc(50% - 50vw);
    overflow: hidden;
    position: relative;
    padding: 0;
    -webkit-mask-image: linear-gradient(to right, transparent 0%, #000 12%, #000 88%, transparent 100%);
    mask-image: linear-gradient(to right, transparent 0%, #000 12%, #000 88%, transparent 100%);
    --card-w: 265px;
    --card-h: 175px;
    --gap: 20px;
    --set-w: calc((var(--card-w) + var(--gap)) * 5);
  }

  .about__images--marquee .about__track {
    display: flex;
    gap: var(--gap);
    width: max-content;
    will-change: transform;
    animation: aboutMarquee 70s linear infinite;
  }

  .about__images--marquee .about__img {
    width: var(--card-w);
    height: var(--card-h);
    flex: 0 0 var(--card-w);
    margin: 0;
    border-radius: 10px;
    overflow: hidden;
    background: transparent;
  }

  .about__images--marquee .about__img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    vertical-align: top;
  }

  @keyframes aboutMarquee {
    0%   { transform: translateX(0); }
    100% { transform: translateX(calc(-1 * var(--set-w))); }
  }
}

/* Environment
========================================================= */
.environment {
  position: relative;
  overflow: hidden;
  background: #FBF7F3;
  padding: 110px 0;
  color: #4A5D73;
}

.environment__grad {
  position: absolute;
  pointer-events: none;
  user-select: none;
  z-index: 0;
  opacity: 0.55;
}

.environment__grad--right    { top: -120px;    right: -160px;  width: 560px; }
.environment__grad--leftTop  { top: -160px;    left: -220px;   width: 560px; opacity: 0.35; }
.environment__grad--leftBottom { bottom: -220px; left: -260px; width: 560px; opacity: 0.25; }

.environment__inner {
  width: min(1000px, calc(100% - 40px));
  margin: 0 auto;
  position: relative;
  z-index: 1;
  text-align: center;
}

.environment__title {
  margin: 0 0 0;
  font-family: "Shippori Mincho", serif;
  font-weight: 500;
  font-size: 36px;
  line-height: 1.6;
  letter-spacing: 0.2em;
  color: #4A5D73;
}

.environment__lead {
  margin: 16px auto 0;
  max-width: 90ch;
  font-family: "Zen Maru Gothic", sans-serif;
  font-weight: 400;
  font-size: 16px;
  line-height: 1.85;
  letter-spacing: 0.07em;
  color: rgba(74, 93, 115, 0.95);
}

.environment__circles {
  display: grid;
  grid-template-columns: repeat(2, 340px);
  justify-content: center;
  gap: 24px 60px;
  margin-top: 40px;
}

.environment__circle:first-child {
  grid-column: 1 / 3;
  justify-self: center;
}

.environment__circle {
  width: 340px;
  height: 340px;
  border-radius: 50%;
  background: rgba(210, 218, 206, 0.9);
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  padding: 0 36px;
  text-align: center;
}

.environment__circleTitle {
  margin: 0 0 12px;
  font-size: 18px;
  letter-spacing: 0.18em;
}

.environment__circleText {
  margin: 0;
  font-size: 13px;
  line-height: 1.85;
}

.environment__illust {
  margin-top: 24px;
  display: flex;
  justify-content: center;
}

.environment__illust img {
  width: 180px;
  height: auto;
  display: block;
}

.environment__btn {
  display: block;
  width: fit-content;
  margin: 48px auto 0;
  line-height: 0;
  text-decoration: none;
}

.environment__btn img {
  display: block;
  width: 360px;
  height: auto;
}

.envCarousel { display: none; }

/* Member
========================================================= */
.memberSec {
  position: relative;
  padding: 120px 0 120px;
  background: #fbfaf7;
  overflow: hidden;
}

/* カンプ準拠の背景グラデーション */
.memberSec::before {
  content: "";
  position: absolute;
  top: -80px;
  left: -160px;
  width: 480px;
  height: 480px;
  background: radial-gradient(circle, rgba(217, 160, 127, 0.22) 0%, rgba(217, 160, 127, 0) 65%);
  pointer-events: none;
  z-index: 0;
}

.memberSec::after {
  content: "";
  position: absolute;
  bottom: -60px;
  right: -140px;
  width: 420px;
  height: 420px;
  background: radial-gradient(circle, rgba(242, 180, 120, 0.18) 0%, rgba(242, 180, 120, 0) 65%);
  pointer-events: none;
  z-index: 0;
}

.memberSec__inner {
  position: relative;
  z-index: 1;
  width: min(1380px, calc(100% - 80px));
  margin: 0 auto;
  text-align: center;
}

.memberSec__title {
  margin: 0;
  font-family: "Shippori Mincho", serif;
  font-weight: 500;
  font-size: 36px;
  line-height: 1.6;
  letter-spacing: 0.2em;
  color: #4A5D73;
}

.memberSec__lead {
  margin: 16px auto 0;
  max-width: 90ch;
  font-family: "Zen Maru Gothic", sans-serif;
  font-weight: 400;
  font-size: 16px;
  line-height: 1.85;
  letter-spacing: 0.07em;
  color: rgba(74, 93, 115, 0.95);
}

.memberSec__cards {
  margin: 40px auto 0;
  padding: 0;
  list-style: none;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  justify-content: center;
  gap: 24px;
  max-width: 1320px;
}

.mCard { width: 100%; }

.mCard__top {
  position: relative;
  width: 100%;
  aspect-ratio: 3 / 4;
  background: #f2ddd7;
  border-radius: 24px 24px 0 0;
  overflow: hidden;
}

.mCard__img {
  position: absolute;
  left: 50%;
  /* top基準で配置：頭が切れないよう上から配置し、bottom:autoで下は自然に */
  top: 0;
  bottom: auto;
  width: auto;
  height: 100%;        /* カードの高さいっぱいに収める */
  max-width: none;
  object-fit: contain;
  object-position: bottom center;
  display: block;
  transform: translateX(-50%);
}

/* 各メンバー：元画像の人物サイズ・余白が異なるため height で統一感を調整 */
.mCard--01 .mCard__img { height: 95%; top: 5%; }
.mCard--02 .mCard__img { height: 95%; top: 5%; object-position: top center; }
.mCard--03 .mCard__img { height: 95%; top: 5%; }
.mCard--04 .mCard__img { height: 98%; top: 2%; }

/* 吹き出し：カード下部寄り */
.mCard__quote {
  position: absolute;
  left: 12px;
  bottom: 28px;
  margin: 0;
  text-align: left;
  font-family: "Zen Maru Gothic", sans-serif;
  font-size: 12px;
  line-height: 1.9;
  letter-spacing: 0.08em;
  color: rgba(66, 74, 91, 0.9);
  z-index: 2;
}

.mCard__quote span {
  display: inline-flex;
  align-items: center;
  height: 36px;
  background: rgba(255, 255, 255, 0.92);
  padding: 0 10px;
  border-radius: 2px;
  box-decoration-break: clone;
  -webkit-box-decoration-break: clone;
}

.mCard__bottom {
  width: 100%;
  height: 90px;
  background: #d9a07f;
  border-radius: 0 0 24px 24px;
  padding: 0 16px;
  display: grid;
  place-content: center;
  gap: 8px;
}

.mCard__name {
  margin: 0;
  color: #fff;
  font-family: "Zen Maru Gothic", sans-serif;
  font-size: 16px;
  letter-spacing: 0.14em;
  font-weight: 600;
}

.mCard__role {
  margin: 0;
  color: rgba(255, 255, 255, 0.92);
  font-family: "Zen Maru Gothic", sans-serif;
  font-size: 12px;
  letter-spacing: 0.08em;
}

.memberSec__cta {
  margin-top: 56px;
  display: grid;
  place-items: center;
}

.memberSec__btnImg {
  display: inline-block;
  text-decoration: none;
}

.memberSec__btnImg img {
  display: block;
  width: 360px;
  height: auto;
}

.memberSp { display: none; }

/* Business
========================================================= */
.business {
  position: relative;
  overflow: hidden;
  background: #fbfaf7;
  padding: 120px 0 200px;
  color: #4A5D73;
}

.business::before {
  content: "";
  position: absolute;
  left: -220px;
  bottom: -260px;
  width: 520px;
  height: 520px;
  background: radial-gradient(circle at 30% 30%, rgba(242, 180, 120, 0.22), rgba(242, 180, 120, 0) 60%);
  filter: blur(2px);
  pointer-events: none;
}

.business__inner {
  width: min(1000px, calc(100% - 40px));
  margin: 0 auto;
  text-align: center;
  position: relative;
  z-index: 2;
}

.business__title {
  margin: 0;
  font-family: "Shippori Mincho", serif;
  font-weight: 500;
  font-size: 36px;
  line-height: 1.6;
  letter-spacing: 0.2em;
  color: #4A5D73;
}

.business__lead {
  margin: 16px auto 0;
  max-width: 70ch;
  font-family: "Zen Maru Gothic", sans-serif;
  font-weight: 400;
  font-size: 16px;
  line-height: 1.85;
  letter-spacing: 0.07em;
  color: rgba(74, 93, 115, 0.95);
}

.business__list {
  margin: 56px auto 0;
  display: grid;
  gap: 34px;
}

.businessCard {
  width: 100%;
  background: rgba(255, 255, 255, 0.75);
  border-radius: 24px;
  box-shadow: 0 10px 26px rgba(40, 55, 75, 0.06);
  display: grid;
  align-items: center;
  gap: 32px;
  padding: 40px 52px;
  text-align: left;
}

.businessCard--right { grid-template-columns: 1fr 260px; }
.businessCard--left  { grid-template-columns: 260px 1fr; }

.businessCard__title {
  margin: 0 0 12px;
  font-family: "Zen Maru Gothic", sans-serif;
  font-weight: 500;
  font-size: 18px;
  letter-spacing: 0.10em;
  color: #4A5D73;
}

.businessCard__text {
  margin: 0;
  font-family: "Zen Maru Gothic", sans-serif;
  font-weight: 400;
  font-size: 12px;
  line-height: 2.0;
  letter-spacing: 0.06em;
  color: rgba(74, 93, 115, 0.92);
}

.businessCard__media {
  margin: 0;
  width: 260px;
  height: 140px;
  border-radius: 16px;
  overflow: hidden;
  display: grid;
  place-items: center;
}

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

.business__cta {
  margin-top: 70px;
  display: grid;
  place-items: center;
  position: relative;
  z-index: 3;
}

.business__btn {
  display: inline-block;
  line-height: 0;
  text-decoration: none;
}

.business__btn img {
  width: 360px;
  height: auto;
  display: block;
}

.business__illust {
  position: absolute;
  left: calc(50% - 500px);
  bottom: -35px;
  width: 160px;
  height: auto;
  pointer-events: none;
  z-index: 1;
}

/* Jobs
========================================================= */
.jobs {
  position: relative;
  background: #FAF8F5;
  padding: 120px 0 160px;
  overflow: hidden;
}

.jobs__grad {
  position: absolute;
  pointer-events: none;
  z-index: 0;
}

.jobs__grad--top    { top: -120px;    right: -160px; width: 560px; opacity: 0.30; }
.jobs__grad--bottom { bottom: -220px; left: -220px;  width: 560px; opacity: 0.20; }

.jobs__inner {
  width: min(1000px, calc(100% - 40px));
  margin: 0 auto;
  text-align: center;
  position: relative;
  z-index: 2;
  color: #4A5D73;
  padding-bottom: 80px;
}

.jobs__title {
  margin: 0;
  font-family: "Shippori Mincho", serif;
  font-weight: 500;
  font-size: 36px;
  line-height: 1.6;
  letter-spacing: 0.20em;
  color: #4A5D73;
}

.jobs__lead {
  margin: 16px auto 0;
  max-width: 90ch;
  font-family: "Zen Maru Gothic", sans-serif;
  font-weight: 400;
  font-size: 16px;
  line-height: 1.85;
  letter-spacing: 0.07em;
  color: rgba(74, 93, 115, 0.92);
}

.jobs__list {
  width: min(1000px, 100%);
  margin: 48px auto 0;
  display: grid;
  gap: 18px;
  text-align: left;
}

.jobItem {
  background: #fff;
  border-radius: 24px;
  box-shadow: 0 10px 26px rgba(40, 55, 75, 0.06);
  overflow: hidden;
}

.jobItem__head {
  list-style: none;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 28px;
  height: 80px;
  cursor: pointer;
}

.jobItem__head::-webkit-details-marker { display: none; }
.jobItem > summary { list-style: none; }

.jobItem__name {
  margin: 0;
  font-family: "Zen Maru Gothic", sans-serif;
  font-weight: 700;
  font-size: 18px;
  letter-spacing: 0.08em;
  color: #4A5D73;
}

.jobItem__icon {
  width: 24px;
  height: 24px;
  display: block;
  flex: 0 0 24px;
  object-fit: contain;
  opacity: 0.9;
  transition: transform 220ms ease, opacity 220ms ease;
}

.jobItem[open] .jobItem__icon {
  transform: rotate(180deg);
  opacity: 1;
}

.jobItem__body { padding: 0 28px 26px; }

.jobItem[open] .jobItem__body {
  padding-top: 10px;
  animation: jobBodyIn 240ms ease both;
}

@keyframes jobBodyIn {
  from { opacity: 0; transform: translateY(-6px); }
  to   { opacity: 1; transform: translateY(0); }
}

.jobItem__label {
  margin: 0 0 10px;
  font-family: "Zen Maru Gothic", sans-serif;
  font-weight: 600;
  font-size: 14px;
  letter-spacing: 0.06em;
  color: rgba(74, 93, 115, 0.75);
}

.jobItem__text {
  margin: 0;
  font-family: "Zen Maru Gothic", sans-serif;
  font-weight: 500;
  font-size: 16px;
  line-height: 1.85;
  letter-spacing: 0;
  color: rgba(74, 93, 115, 0.92);
}

.jobs__cta {
  margin-top: 64px;
  display: grid;
  place-items: center;
}

.jobs__btnImg {
  display: inline-block;
  text-decoration: none;
}

.jobs__illust {
  position: absolute;
  right: 18px;
  bottom: 18px;
  width: 150px;
  height: auto;
  pointer-events: none;
  z-index: 1;
}

/* Entry
========================================================= */
.entry {
  width: 100%;
  height: 450px;
  background-image: url("../images/entry-gradient.png");
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  display: flex;
  align-items: center;
  justify-content: center;
}

.entry__inner {
  width: min(1000px, calc(100% - 40px));
  text-align: center;
}

.entry__text {
  font-family: "Shippori Mincho", serif;
  font-weight: 500;
  font-size: 16px;
  letter-spacing: 0.16em;
  line-height: 2.0;
  color: #232847;
  margin: 0 0 32px;
}

.entry__btn {
  display: inline-block;
  text-decoration: none;
  line-height: 0;
}

.entry__btn img {
  width: 408px;
  height: auto;
  display: block;
}

/* Footer
========================================================= */
.footer {
  background: #FAF8F5;
  height: 380px;
  display: flex;
  align-items: center;
}

.footer__inner {
  width: min(1000px, calc(100% - 80px));
  margin: 0 auto;
  text-align: center;
}

.footer__logo img {
  width: 345px;
  height: auto;
  display: block;
  margin: 0 auto;
}

.footer__nav { margin-top: 44px; }

.footer__nav ul {
  max-width: 760px;
  margin: 0 auto;
  padding: 0;
  list-style: none;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 24px;
}

.footer__nav a {
  font-family: "Zen Maru Gothic", sans-serif;
  font-weight: 500;
  font-size: 14px;
  letter-spacing: 0.18em;
  color: rgba(74, 93, 115, 0.92);
  text-decoration: none;
  white-space: nowrap;
}

.footer__nav a:hover { opacity: 0.75; }

.footer__copy {
  margin: 44px 0 0;
  font-size: 12px;
  letter-spacing: 0.14em;
  color: rgba(74, 93, 115, 0.75);
}

/* CTA hover（共通）
========================================================= */
@media (hover: hover) {
  .header__cta img,
  .entry__btn img,
  .about__btn img,
  .environment__btn img,
  .memberSec__btnImg img,
  .business__btn img,
  .jobs__btnImg img {
    transition: transform 220ms ease, opacity 220ms ease, filter 220ms ease;
    will-change: transform, opacity;
  }

  .header__cta:hover img,
  .entry__btn:hover img,
  .about__btn:hover img,
  .environment__btn:hover img,
  .memberSec__btnImg:hover img,
  .business__btn:hover img,
  .jobs__btnImg:hover img {
    transform: translateY(-2px);
    opacity: 0.92;
    filter: drop-shadow(0 10px 18px rgba(40, 55, 75, 0.18));
  }
}

/* アンカー：固定ヘッダー分オフセット
========================================================= */
:root {
  --headerH-pc: 110px;
  --headerH-sp: 64px;
}

#about, #environment, #members, #business, #jobs, #entry {
  scroll-margin-top: calc(var(--headerH-pc) + 16px);
}

/* スクロールアニメーション
========================================================= */

/* 共通：初期状態（非表示・下にずれた状態） */
.js-fadeUp {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity 0.8s cubic-bezier(0.22, 1, 0.36, 1),
              transform 0.8s cubic-bezier(0.22, 1, 0.36, 1);
}

/* 表示状態 */
.js-fadeUp.is-visible {
  opacity: 1;
  transform: translateY(0);
}

/* stagger：親の監視対象（子に is-visible を付与） */
.js-stagger > * {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity 0.75s cubic-bezier(0.22, 1, 0.36, 1),
              transform 0.75s cubic-bezier(0.22, 1, 0.36, 1);
}

.js-stagger > *.is-visible {
  opacity: 1;
  transform: translateY(0);
}

/* Motion safety
========================================================= */
@media (prefers-reduced-motion: reduce) {
  * { scroll-behavior: auto !important; }

  .fv__img,
  .fv__copy-inner,
  .about__grad,
  .about__images--marquee .about__track,
  .jobItem__icon,
  .jobItem[open] .jobItem__body,
  .js-fadeUp,
  .js-stagger > * {
    transition: none !important;
    animation: none !important;
    opacity: 1 !important;
    transform: none !important;
    filter: none !important;
  }
}

/* =========================================================
  SP（max-width: 640px）
========================================================= */
@media (max-width: 640px) {

  /* アンカーオフセット */
  #about, #environment, #members, #business, #jobs, #entry {
    scroll-margin-top: calc(var(--headerH-sp) + 12px);
  }

  /* Header */
  .header {
    height: 64px;
    background: rgba(250, 248, 245, 0.5);
    backdrop-filter: none;
  }

  .header__inner { padding: 0 20px; gap: 0; }
  .header__logo-img--pc { display: none; }
  .header__logo-img--sp { display: block; height: 20px; width: auto; }
  .header__nav  { display: none; }
  .header__cta  { display: none; }
  .header__menu { display: grid; place-items: center; width: 44px; height: 44px; }

  /* SP Nav */
  #spOverlay {
    display: block;
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.35);
    opacity: 0;
    pointer-events: none;
    transition: opacity 200ms ease;
    z-index: 2000;
  }

  #spNav {
    display: block;
    position: fixed;
    top: 64px;
    right: 0;
    width: min(86vw, 320px);
    height: calc(100vh - 64px);
    background: rgba(250, 248, 245, 0.98);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    transform: translateX(105%);
    transition: transform 240ms ease;
    z-index: 2001;
    padding: 22px 18px;
    box-shadow: -10px 0 24px rgba(40, 55, 75, 0.12);
  }

  #spNav .spNav__list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: grid;
    gap: 16px;
  }

  #spNav a {
    text-decoration: none;
    color: #4A5D73;
    font-size: 14px;
    letter-spacing: 0.12em;
  }

  body.is-menuOpen #spOverlay { opacity: 1; pointer-events: auto; }
  body.is-menuOpen #spNav     { transform: translateX(0); }

  /* FV */
  .fv { height: 420px; margin-top: 64px; }

  .fv::before { background: none; }

  .fv::after {
    content: "";
    position: absolute;
    left: 0; right: 0; bottom: 0;
    height: 50%;
    background: rgba(250, 248, 245, 0.46);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    -webkit-mask-image: linear-gradient(to top, rgba(0,0,0,1) 0%, rgba(0,0,0,1) 50%, rgba(0,0,0,0) 100%);
    mask-image: linear-gradient(to top, rgba(0,0,0,1) 0%, rgba(0,0,0,1) 50%, rgba(0,0,0,0) 100%);
    z-index: 2;
    pointer-events: none;
  }

  .fv__copy {
    left: 24px;
    top: auto;
    bottom: 48px;
    max-width: calc(100% - 48px);
    z-index: 3;
    background: transparent;
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
    padding: 0;
    border-radius: 0;
  }

  .fv__sub { margin-bottom: 14px; }
  .fv__sub-logo { width: 120px; }
  .fv__sub-text { font-size: 11px; letter-spacing: 0.26em; }

  .fv__title { font-size: 26px; line-height: 1.6; letter-spacing: 0.14em; }
  .fv__title-line { white-space: normal; }
  .fv__title-line--second { margin-top: 8px; }

  /* About */
  .about { padding: 64px 24px; }
  .about__title { font-size: 20px; margin-bottom: 20px; text-align: center !important; }
  .about__copy {
    font-size: 13px;
    line-height: 2.2;
    letter-spacing: 0.08em;
    margin-bottom: 28px;
    max-width: 100%;
    text-align: center;
  }
  .about__copy p {
    display: block;
    margin: 0;
    padding: 0;
  }
  .about__btn { margin-bottom: 32px; }
  .about__btn img { width: 200px; }

  .about__images--marquee {
    width: 100%;
    margin: 0;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    -webkit-mask-image: none;
    mask-image: none;
  }

  .about__images--marquee .about__track {
    animation: none;
    display: flex;
    gap: 10px;
    width: max-content;
  }

  .about__images--marquee .about__img {
    width: 160px;
    height: 108px;
    flex: 0 0 160px;
  }

  /* Environment */
  .environment { padding: 64px 0; }
  .environment__inner { width: calc(100% - 48px); text-align: left; }
  .environment__title { font-size: 20px; line-height: 1.8; letter-spacing: 0.12em; text-align: center !important; }
  .environment__lead  { font-size: 13px; line-height: 1.85; letter-spacing: 0.06em; margin-top: 14px; text-align: left; max-width: 100%; }
  .environment__illust { display: none; }
  .environment__btn { margin-top: 32px; }
  .environment__btn img { width: 200px; }

  .environment__circles { display: none; }

  .envCarousel {
    display: grid;
    margin-top: 28px;
    grid-template-columns: 32px 1fr 32px;
    gap: 4px;
    align-items: center;
  }

  .envCarousel__btn--prev,
  .envCarousel__btn--next {
    background: none;
    border: none;
    font-size: 24px;
    color: #4A5D73;
    cursor: pointer;
    padding: 0;
    display: grid;
    place-items: center;
  }

  .envCarousel__track {
    overflow: hidden;
    display: flex;
    scroll-snap-type: x mandatory;
    scroll-behavior: smooth;
  }

  .envCarousel .environment__circle {
    flex: 0 0 100%;
    width: 100%;
    min-height: 220px;
    height: auto;
    border-radius: 16px;
    background: rgba(183, 196, 177, 0.7);
    padding: 32px 28px;
    justify-content: center;
    gap: 14px;
    text-align: center;
  }

  .envCarousel .environment__circleTitle {
    font-size: 16px;
    letter-spacing: 0.16em;
    margin: 0 0 12px;
  }
  .envCarousel .environment__circleText {
    font-size: 13px;
    line-height: 1.85;
    letter-spacing: 0.04em;
    margin: 0;
  }

  /* Member */
  .memberSec { padding: 64px 0; }
  .memberSec__inner { width: calc(100% - 48px); text-align: left; }
  .memberSec__title { font-size: 20px; line-height: 1.8; text-align: center !important; }
  .memberSec__lead  { font-size: 13px; line-height: 1.85; letter-spacing: 0.06em; margin-top: 14px; text-align: left; max-width: 100%; }

  .memberSec__cards { display: none; }

  .memberSp {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 12px;
    margin-top: 28px;
  }

  .memberSp img {
    width: 100%;
    height: auto;
    display: block;
    border-radius: 16px;
  }

  .memberSec__cta { margin-top: 32px; }
  .memberSec__btnImg img { width: 200px; }

  /* Business */
  .business { padding: 64px 0; }
  .business__inner { width: calc(100% - 48px); text-align: left; }
  .business__title { font-size: 20px; line-height: 1.8; text-align: center !important; }
  .business__lead  { font-size: 13px; line-height: 1.85; letter-spacing: 0.06em; margin-top: 14px; text-align: left; max-width: 100%; }
  .business__illust { display: none; }
  .business__list { margin-top: 28px; gap: 16px; }

  .businessCard {
    grid-template-columns: 1fr;
    padding: 20px 16px;
    gap: 14px;
    border-radius: 16px;
  }

  .businessCard--right,
  .businessCard--left { grid-template-columns: 1fr; }

  /* SPでは画像を常に上に表示 */
  .businessCard--left .businessCard__media { order: -1; }

  .businessCard__media { width: 100%; height: auto; aspect-ratio: 16 / 9; border-radius: 12px; }
  .businessCard__title { font-size: 15px; margin-bottom: 6px; }
  .businessCard__text  { font-size: 13px; line-height: 1.85; }
  .business__cta { margin-top: 36px; }
  .business__btn img { width: 200px; }

  /* Jobs */
  .jobs { padding: 64px 0; }
  .jobs__inner  { width: calc(100% - 48px); padding-bottom: 40px; text-align: left; }
  .jobs__title  { font-size: 20px; line-height: 1.8; text-align: center !important; }
  .jobs__lead   { font-size: 13px; line-height: 1.85; letter-spacing: 0.06em; margin-top: 14px; text-align: left; max-width: 100%; }
  .jobs__illust { display: none; }
  .jobs__list   { margin-top: 28px; gap: 10px; }

  .jobItem { border-radius: 14px; }
  .jobItem__head { height: 60px; padding: 0 20px; }
  .jobItem__name { font-size: 14px; letter-spacing: 0.06em; }
  .jobItem__label { font-size: 12px; }
  .jobItem__text  { font-size: 13px; line-height: 1.85; }
  .jobs__cta { margin-top: 36px; }
  .jobs__btnImg img { width: 200px; }

  /* Entry */
  .entry { height: auto; padding: 64px 0; }
  .entry__inner { width: calc(100% - 48px); }
  .entry__text  { font-size: 13px; line-height: 2.0; letter-spacing: 0.1em; margin-bottom: 24px; text-align: center; }
  .entry__btn img { width: 220px; }

  /* Footer */
  .footer { height: auto; padding: 48px 0; }
  .footer__inner  { width: calc(100% - 48px); }
  .footer__logo img { width: 200px; }
  .footer__nav { margin-top: 28px; }
  .footer__nav ul { flex-direction: column; gap: 18px; }
  .footer__nav a { font-size: 13px; }
  .footer__copy { margin-top: 28px; font-size: 11px; }
}