/* --------------------------------------------------------------
  PAGE HEADER
---------------------------------------------------------------- */
.page-hero__image {
  top: 0;
  right: -20%;
  max-width: 100%;
}
.parallax-wrap [data-hero-img] {
  height: 130%;
}

@media screen and (max-width: 699px) {
  #company .page-hero__title h1 {
    line-height: 1.1;
  }
}

@media screen and (max-width: 699px) {
  .page-hero {
    overflow: visible;
  }
  .page-hero__image {
    right: -15%;
    width: 100vw;
    max-width: 100vw;
    margin-top: 1.5em;
    margin-inline: calc(50% - 50vw);
  }
  .page-hero__image svg {
    width: 100%;
    height: auto;
    transform: none;
  }
}

@media screen and (max-width: 499px) {
  .page-hero__image {
    right: -10%;
  }
}



/* --------------------------------------------------------------
  COMPANY PROFILE / 会社概要
---------------------------------------------------------------- */
.company-profile {
  padding: 0;
  margin-inline-start: 10%;
}
.company-profile dl {
  width: 70%;
  display: grid;
  grid-template-columns: 10em 1fr;
  gap: 0;
  border-bottom: 1px solid var(--color-primary);
  font-size: 14px;
}
.company-profile dt,
.company-profile dd {
  padding-block: 1.4em;
  border-top: 1px solid var(--color-primary);
}

.company-profile dd {
  line-height: 2;
}
.company-profile dd strong {
  display: inline-block;
  margin-bottom: .25em;
  font-weight: 700;
}

.company-profile .button {
  margin-block: .8em 2em;
}

@media screen and (max-width: 699px) {
  .company-profile {
    margin-inline-start: 0;
  }
  .company-profile dl {
    width: 80%;
    margin-inline: auto;
    grid-template-columns: 7em 1fr;
  }
  .company-profile dt,
  .company-profile dd {
    padding-block: 18px;
    font-size: 12px;
  }
}

@media screen and (max-width: 499px) {
  .company-profile dl {
    width: 100%;
  }
}


/* ===== Motion base（ゆっくり版） ===== */
@media (prefers-reduced-motion: reduce) {
  * { animation: none !important; transition: none !important; }
}

.motion {
  opacity: 0;
  transform: translateY(16px);
  transition: opacity .95s ease, transform .95s cubic-bezier(.2,.7,.2,1);
  will-change: transform, opacity;
}
.motion.in {
  opacity: 1;
  transform: none;
}

/* 方向別の初期オフセット */
.motion-left  { transform: translateX(-24px); }
.motion-right { transform: translateX(24px);  }
.motion-up    { transform: translateY(24px);  }
.motion-down  { transform: translateY(-24px); }

/* クリップ演出をゆっくりに */
.motion-clip {
  opacity: 1;
  transform: none;
  clip-path: inset(0 0 100% 0);
  transition: clip-path 1.4s cubic-bezier(.2,.7,.2,1);
}
.motion-clip.in { clip-path: inset(0 0 0 0); }

/* ふわゆら：周期をゆっくり（12s） */
@keyframes floatY {
  0%,100% { transform: translateY(0); }
  50%     { transform: translateY(-8px); }
}
.float { animation: floatY 12s ease-in-out infinite; }

/* ホバーはほんのり */
.button .dli-arrow-right { transition: transform .3s ease; }
.button:hover .dli-arrow-right { transform: translateX(3px); }








/* --------------------------------------------------------------
  COMPANY / PHILOSOPHY
---------------------------------------------------------------- */
.company-ttl {
  margin-block-end: 1em;
}
.company-ttl h2 {
  font-size: var(--font-size-24);
  letter-spacing: var(--ls-15);
  font-weight: 400;
  color: var(--color-corporate);
}

.philosophy__lead {
  padding-block: var(--space-xl);
  text-align: center;
}
.philosophy_lead__header {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-sm);
  margin-block-end: var(--space-4);
  margin-inline-end: calc(2em + var(--space-sm));
}
.philosophy-lead__header > span{
  display: inline-grid;
  color: var(--color-corporate);
  font-weight: 400;
  letter-spacing: .1em;
}
.philosophy-lead__header img{
  height: clamp(60px, 9vw, 110px);
  width: auto;
}

.philosophy-lead__body {
  width: 80%;
  margin-inline: auto;
}
.philosophy-lead__body .txt {
  text-align: center;
  color: var(--color-corporate);
  font-weight: 400;
  letter-spacing: var(--ls-15);

  text-decoration: underline;
  text-underline-offset: 0.5em;
  text-decoration-thickness: 0.08em;
}

/* 青いふわふわ丸 */
.wa-circles {
  display: flex;
  align-items: center;
  justify-content: space-evenly;
  margin-block: var(--space-5);
  margin-block: 4em;
}

.orb {
  position: relative;
  inline-size: clamp(280px, 24vw, 328px);
  inline-size: clamp(275px, calc(6.108vw + 244.52px), 328px);
  aspect-ratio: 1/1;
  border-radius: 50%;
  background: #fff;
  display: grid;
  place-items: center;
  animation: floatY 6.5s ease-in-out infinite;
  will-change: transform;
  box-shadow:
    0 15px 15px color-mix(in oklab, var(--color-corporate, var(--color-primary)) 20%, transparent),
    0 15px 15px rgba(32, 64, 120, .12),
    0 -15px 15px color-mix(in oklab, var(--color-corporate, var(--color-primary)) 20%, transparent),
    0 -15px 15px rgba(32, 64, 120, .12),
    18px 0 22px color-mix(in oklab, var(--color-primary) 16%, transparent),
    -18px 0 22px color-mix(in oklab, var(--color-corporate, var(--color-primary)) 16%, transparent),
    8px 0 12px rgba(32, 64, 120, .08),
    -8px 0 12px rgba(32, 64, 120, .08),
    0 1px 0 rgba(0,0,0,.08);
}
.orb--alt{
  animation-name: floatXY;
  animation-duration: 7.2s;
  animation-delay: .25s;
}
.orb__content{
  width: 78%;
  text-align: center;
}
.orb__content h3 {
  font-size: clamp(18px, 24vw, 20px);
}
.orb__content p {
  line-height: 1.9;
  font-size: clamp(var(--font-size-10), 24vw, var(--font-size-14));
}

@media screen and (max-width: 799px) {
  .philosophy-lead__body {
    width: 100%;
    margin-block-start: 3em;
  }
}


@media screen and (max-width: 699px) {
  .philosophy-lead__header {
    flex-direction: column;
    align-items: flex-start;
    margin-inline-end: 0;
  }
  .philosophy-lead__header img {
    max-width: auto;
    width: 100%;
    height: auto;
  }
  .philosophy-lead__header > span {
    font-size: 24px;
  }

  .wa-circles{
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0;
    margin-block: 5em;
  }
  .wa-circles .orb:nth-child(odd) {
    margin-left: 0;
    margin-right: auto;
  }
  .wa-circles .orb:nth-child(even) {
    margin-left: auto;
    margin-right: 0;
  }

  .philosophy-lead__body .txt {
    font-size: 16px;
    line-height: 2.2;
  }
}


@media screen and (max-width: 499px) {
  .wa-circles{
    gap: 50px;
  }
}

/* 動きが苦手な人向け */
@media (prefers-reduced-motion: reduce){
  .orb, .orb::before{ animation: none !important; }
}



/* ===== 経営理念（リスト） ===== */
.company-philosophy__principles {
  padding-block: var(--space-xl);
}
.company-philosophy__principles-body {
  width: calc(100% - 3em);
  margin-left: auto;
}
.company-philosophy__principles-body ol {
  counter-reset: principle;
  display: grid;
  gap: 4.5em;
  padding: 0;
  margin: 0;
  list-style: outside;
}
.company-philosophy__principles-body li {
  margin: 0;
  position: relative;
  padding-inline-start: 1.5em;
  list-style: none;
}
.company-philosophy__principles-body li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.7em;
  width: 6px;
  height: 6px;
  background-color: var(--color-primary);
  border-radius: 50%;
}
.company-philosophy__principles-body li h3 {
  margin: 0;
  line-height: 1.5;
  font-size: var(--font-size-18);
  font-weight: 600;
  letter-spacing: var(--ls-10);
}
.company-philosophy__principles-body li span {
  margin-block: .3em;
  display: inline-block;
  font-size: var(--font-size-14);
  color: var(--color-primary);
  letter-spacing: var(--ls-15);
}
.company-philosophy__principles-body li p {
  margin: 0;
  letter-spacing: var(--ls-10);
}

/* モバイル */
@media screen and (max-width: 699px) {
  .company-philosophy__principles{
  }
  .company-philosophy__principles-body {
    width: calc(100% - 1em);
  }
}

/* ===== シンボルマーク ===== */
.company-philosophy__symbol {
  padding-block: var(--space-xl);
}
.company-philosophy__symbol-body {
  width: calc(100% - 3em);
  margin-left: auto;

  display: flex;
  flex-direction: column;
  gap: var(--space-xl);
  align-items: center;
}
.company-philosophy__symbol-body img {
  width: 270px;
  height: auto;
  display: block;
}
.company-philosophy__symbol-body p {
  line-height: 1.9;
  color: var(--ink);
}

/* モバイル */
@media screen and (max-width: 699px) {
  .company-philosophy__symbol {
    margin-block-start: 3em;
  }
  .company-philosophy__symbol-body{
    width: 100%;
    margin-block-start: 3em;
    gap: 3em;
  }

  .company-philosophy__symbol-body img {
    width: 170px;
  }
}




/* ===== キーフレーム ===== */
@keyframes floatY{
  0%,100% {
    transform: translateY(0) rotate(.2deg);
  }
  50% {
    transform: translateY(-10px) rotate(-.2deg);
  }
}
@keyframes floatXY{
  0%,100% {
    transform: translate(0,0) rotate(.2deg);
  }
  50% {
    transform: translate(6px,-12px) rotate(-.3deg);
  }
}
@keyframes halo {
  0%,100% {
    filter: blur(10px) opacity(.55);
  }
  50% {
    filter: blur(14px) opacity(.85);
  }
}



:root{
  --timeline-width: 2px;
  --timeline-x: 127px; /* 左の年号幅 + 余白 */
}





/* --------------------------------------------------------------
  COMPANY / HISTORY
---------------------------------------------------------------- */
.history_lead__header h2 {
  font-size: var(--font-size-24);
  color: var(--color-corporate);
  font-weight: 600;
  letter-spacing: var(--ls-8);
}
.history_lead__header p {
  font-size: var(--font-size-14);
  line-height: 1.85;
  letter-spacing: var(--ls-10);
}

/* 全体 */
.timeline {
  position: relative;
  max-width: 1100px;
  margin: 0 auto;
  padding: 4em 1em;
}

.timeline__footer {
  margin-block-start: 1em;
}
.timeline__footer p {
  font-size: var(--font-size-17);
  color: var(--color-corporate);
  letter-spacing: var(--ls-5);
  font-weight: 500;
  line-height: 1.94;
}


/* 各年 */
.tl-item {
  position: relative;
  display: grid;
  grid-template-columns: 160px 1fr;
  grid-template-columns: 100px 1fr;
  gap: 2em;
  align-items: start;
  position: relative;
  padding-block-end: 5em;
}
.tl-item::before {
  content: "";
  position: absolute;
  left: var(--timeline-x, 203px);   /* 年号と本文の境目に一致させる */
  top: 0;
  bottom: 0;
  width: var(--timeline-width, 2px);
  background: linear-gradient(#d9d9d9, #e6e6e6);
  z-index: 0;
}

.tl-year,
.tl-body {
  position: relative;
  z-index: 1;

}
.tl-year{
  padding-right: 1em;
}
.tl-year__year{
  font-size: var(--font-size-24);
  letter-spacing: 0;
  line-height: 1;
  font-weight: 900;
  margin: 0;
}
.tl-year__jp {
  margin-block-start: .2em;
  font-size: var(--font-size-12);
  letter-spacing: var(--ls-10);
}

.tl-body {
  position: relative;
  padding-left: 2.2em;
  display: flex;
}
.tl-body::before{
  content:"";
  position:absolute;
  left: -11px;
  top: 0.55em;
  width: 14px;
  height: 14px;
  background: var(--color-corporate);
  border-radius: 999px;
}

.tl-photo{
  margin: 0 1.5em 0 0;
}
.tl-photo img{
  display: block;
  width: 270px;
  height: auto;
  border-radius: 20px;
}

.tl-points {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 1.5em;
}

.tl-points > li {
  display: flex;
  align-items: flex-start;
  position: relative;
  padding-left: 1.2em;
  line-height: 1.9;
  color: var(--ink);
}

.tl-points > li::before {
  content:"";
  position:absolute;
  left: 0;
  top: .85em;
  width: .4em;
  height: .4em;
  border-radius: 50%;
  background: var(--color-primary);
}

.tl-points b {
  flex-shrink: 0;
  min-width: 3em;
  font-weight: 700;
  font-size: var(--font-size-14);
  letter-spacing: var(--ls-15);
  margin-right: .3em;
}

.tl-points span {
  flex: 1;
  font-size: var(--font-size-14);
  letter-spacing: var(--ls-10);
}

.tl-item:first-child::before {
  top: .55em;
}


@media screen and (max-width: 840px){
  :root{
    --timeline-x: -6px;
  }
  .tl-item{
    grid-template-columns: 1fr;
    gap: .6em 1.5em;
    padding-block: 1.8em;
  }
  .tl-year{
    text-align: left;
    padding-right: 0;
    padding-left: 2.2em;
    position: relative;
  }
}

@media screen and (max-width: 699px) {
  .tl-body {
    flex-direction: column;
    padding-left: 1.5em;
  }
  .tl-body::before {
    top: -3.45em;
  }
  .tl-item:first-child::before {
    top: 2.55em;
  }
  .tl-year {
    padding-left: 1.5em;
  }
  .tl-year__jp {
    margin-block-end: 0;
  }
  .tl-photo {
    margin: 0 0 1.5em 0;
  }
  .tl-photo img {
    width: 100%;
    margin-block-end: 1em;
  }
  .tl-points {
    margin-inline-start: 1em;
  }
  .tl-points > li {
    flex-direction: column;
  }
  .tl-points > li::before {
    top: 0.7em;
  }
}

@media screen and (max-width: 499px) {
  .tl-body,
  .tl-year {
    padding-left: 1.2em;
  }

  .tl-photo {
    margin: 0;
  }
}