@charset "UTF-8";



:root {
  --bg: #f8f8ff;
  --ink: #333333;
  --mute: #6B7280;
  --border: #E5E7EB;
  --accent: #D62828;
  --blue: #4F65FF;

  --line-works: #4F65FF;
  --line-about: #FF8800;
  --line-contact: #FF0000;

  --feature-ratio: 16 / 10;

  /* 上段の横長カード比率 */

  --sidebar-w: min(16.666vw, 320px);
  --content-max: 1500px;
  --sp-content: 330px;

  --ff-en: "Aboreto", system-ui, sans-serif;
  --ff-ja: "Noto Sans JP", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;

  --fs-body: 16px;
  --fs-nav: 24px;
  --fs-title: clamp(24px, 6vw, 40px);

  --shadow-1: 0 6px 18px rgba(0, 0, 0, .08);
}




.main {
  margin-left: var(--sidebar-w)
}

.wrapper {
  max-width: var(--content-max);
  margin: 0 auto;
  padding: 72px 72px
}

main h1 {
  color: #4F65FF;

}






@keyframes charFade {
  0% {
    opacity: 0;
    transform: translateY(12px);
  }

  100% {
    opacity: 1;
    transform: translateY(0);
  }
}





.process {
  color: #4F65FF;
  font-size: 24px;
  padding-bottom: clamp(3.75rem, 2.430rem + 5.634vw, 7.5rem);
}

.work-images .repitop {
  justify-self: center;
}

.repitop {
  display: block;
  margin-inline: auto;
  width: clamp(17.5rem, 10.458rem + 30.047vw, 37.5rem);
}





.reveal_p {
  font-size: 20px;
}

/* .section_title::before {
  content: "";
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  width: 64px;
  height: 2px;
  background: var(--line-works);
  border-radius: 2px
} */

.brief {
  margin: 18px 0
}


.brief_row {
  display: grid;
  grid-template-columns: 120px 1fr;
  gap: 18px;
  padding: 8px 0;
  border-bottom: 1px solid var(--border)
}

.brief_row dt {
  color: #111;
  font-weight: 600;
  font-size: 14px
}

.brief_row dd {
  margin: 0;
  color: #333
}



/* 画像2枚横並び用 */
.work-images {
  display: grid;
  gap: 16px
}

.work-images--row {
  grid-template-columns: 1fr 1fr;
}

.work-images figure {
  margin: 0;

  overflow: hidden
}

.work_p {
  margin-bottom:clamp(3.125rem, 2.025rem + 4.695vw, 6.25rem);
  padding-top: 20px;
}

.is-pc img {
  width: 690px;
}

.is-sp img {
  width: 300px;
}

.work_text {
  font-size: 30px;
}

.Repi1 {
  width: 70%;
  margin-left: 100px;
  padding-bottom: 40px;
}

.Repi2 {
  width: 70%;
}

.Repi3 {
  width: 70%;
  padding-bottom: 80px;
}

.card_meta {
  padding-bottom: 20px;
}

#top {
  margin-bottom: 100px;
}

/* スライダー（pasta用） */
.slider {
  position: relative;
  margin-top: 16px;
  transition: transform .35s, box-shadow .35s
}

/* .slider:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-1)
} */

.slider_viewport {
  overflow: hidden;
  border-radius: 8px
}

.slider_track {
  display: grid;
  grid-auto-flow: column;
  grid-auto-columns: 100%;
  transition: transform .5s ease;
  will-change: transform
}

.slide img {
  display: block;
  width: 100%
}

.slider_arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  border: none;
  background: rgba(0, 0, 0, .45);
  color: #fff;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  cursor: pointer
}

.slider_arrow--prev {
  left: 10px
}

.slider_arrow--next {
  right: 10px
}

.dots {
  display: flex;
  justify-content: center;
  gap: 10px;
  margin-top: 12px
}

.dot {
  width: 8px;
  height: 8px;
  display: inline-block;
  border-radius: 50%;
  background: #CBD5E1;
  border: none;
  cursor: pointer;
  flex-shrink: 0;
}

.dot.is-active {
  background: #475569
}




/* サイトに飛ぶボタン */
.button-30 {
  display: flex;
  justify-content: center;
  align-items: center;
  position: relative;
  width: 250px;
  margin: 0 auto;
  padding: .9em 2em;
  border: 1px solid #24a0ff;
  border-radius: 5px;
  background-color: #fff;
  color: #24a0ff;
  font-size: 1em;
}

.workbtn {
  padding-top: 80px;
}

.button-30:hover {
  animation: anima-button-30 1s;
}

@keyframes anima-button-30 {
  0% {
    box-shadow: 0 0 0 0 rgb(36 160 255 / 50%);
  }

  100% {
    box-shadow: 0 0 0 1.2em rgb(0 0 0 / 0%);
  }
}

.button-30::after {
  transform: rotate(45deg);
  width: 5px;
  height: 5px;
  margin-left: 10px;
  border-top: 2px solid #24a0ff;
  border-right: 2px solid #24a0ff;
  content: '';
}






@media (max-width: 768px) {
  :root {
    --sidebar-w: 0px
  }

  .sidebar {
    display: none
  }

  .sp-header {
    display: block
  }

  .main {
    margin-left: 0
  }

  .wrapper {
    max-width: var(--sp-content);
    padding: 28px 16px
  }

  .brief_row {
    grid-template-columns: 90px 1fr
  }

  .work-images--row {
    grid-template-columns: 1fr;
  }

  /* SPは縦並び */
  .footer .wrapper {
    padding: 16px
  }
}