:root {
  --page-bg: #f2ebe5;
}

* {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
}

body {
  margin: 0;
  background: var(--page-bg);
  color: #231815;
  font-family: "Noto Sans JP", "Hiragino Kaku Gothic ProN", "Yu Gothic", sans-serif;
  overflow-x: hidden;
}

.lp {
  min-height: 100vh;
}

.page {
  width: min(100vw, 1280px);
  margin: 0 auto;
  overflow: visible;
  background: var(--page-bg);
}

.page--sp {
  display: none;
}

.slice {
  position: relative;
  width: 100%;
  overflow: hidden;
}

.slice:not(.hero) > img {
  display: block;
  width: 100%;
  height: auto;
  max-width: none;
  user-select: none;
}

.hotspot {
  position: absolute;
  display: block;
  border-radius: 14px;
  color: transparent;
  text-decoration: none;
}

.hotspot:focus-visible {
  outline: 3px solid #eb5f20;
  outline-offset: 5px;
}

.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

.pc-hero {
  aspect-ratio: 1280 / 764;
  background: #f2ebe5;
}

.hero {
  isolation: isolate;
}

.hero a {
  color: inherit;
  text-decoration: none;
}

.hero img {
  display: block;
  max-width: none;
  user-select: none;
}

.hero-logo,
.hero-person,
.hero-glasses,
.hero-cta,
.hero-lead,
.hero-title,
.hero-title__part,
.hero-signature,
.hero-menu,
.sp-header-cta {
  position: absolute;
}

.sp-header {
  display: none;
}

.sp-menu {
  display: none;
}

.hero-logo {
  left: 3.125%;
  top: 5.24%;
  z-index: 8;
  width: 19.92%;
}

.hero-logo img {
  width: 100%;
  height: auto;
}

.hero-lead {
  left: 3.125%;
  top: 16.9%;
  z-index: 8;
  width: 20.2%;
  margin: 0;
  font-size: clamp(9px, 0.86vw, 11px);
  font-weight: 400;
  line-height: 1.5;
}

.hero-person {
  left: 44%;
  bottom: 0;
  z-index: 3;
  width: 46.875%;
  max-width: 600px;
  height: auto;
  transform: translateX(-50%);
}

.hero-title {
  inset: 0;
  z-index: 5;
  margin: 0;
  color: #463d3a;
  font-size: clamp(48px, 7.5vw, 96px);
  line-height: 1;
  letter-spacing: 0;
}

.hero-title__part {
  display: block;
  white-space: nowrap;
  font-weight: 500;
  z-index: 4;
}

.hero-title__part--world {
  left: 3.125%;
  top: 35.4%;
}

.hero-title__part--change {
  left: 55.6%;
  top: 35.4%;
}

.hero-title__part--one {
  left: 3.125%;
  top: 53.9%;
  mix-blend-mode: color-burn;
}

.hero-title__part--trigger {
  left: 51.95%;
  top: 53.7%;
  z-index: 6;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 29.7%;
  height: 13.87%;
  padding-bottom: 0.1em;
  background: #eb5f20;
  color: #fff;
}

@media (min-width: 768px) {
  .hero-title__part--one {
    mix-blend-mode: color-burn;
  }

  .hero-title__part--trigger {
    mix-blend-mode: hard-light;
  }
}

.hero-title__part--from {
  left: 82.5%;
  top: 52.8%;
}

.hero-glasses {
  left: 66.25%;
  top: 66.4%;
  z-index: 5;
  width: 22.9%;
  height: auto;
  mix-blend-mode: multiply;
}

.hero-signature {
  left: 59.45%;
  top: 87.2%;
  z-index: 7;
  margin: 0;
  font-size: clamp(10px, 1.09vw, 14px);
  line-height: 1.3;
}

.hero-cta {
  left: 52.28%;
  top: 11.78%;
  z-index: 9;
  display: block;
  width: 30.42%;
  height: 25.15%;
}

.hero-cta::before {
  position: absolute;
  left: 0.95%;
  top: 8.56%;
  z-index: 0;
  width: 98.1%;
  height: 44%;
  border-radius: 10px;
  background: #fff;
  box-shadow: 0 5px 10px rgba(0, 0, 0, 0.1);
  content: "";
  transform: rotate(5deg);
}

.hero-cta span {
  position: absolute;
  left: 6.4%;
  top: 23.7%;
  z-index: 1;
  display: block;
  width: 87.5%;
  color: #231815;
  font-size: clamp(12px, 1.48vw, 19px);
  font-weight: 700;
  line-height: 1.3;
  text-align: center;
  transform: rotate(5deg);
  white-space: nowrap;
}

.hero-cta strong {
  color: #eb5f20;
}

.hero-cta img {
  position: absolute;
  left: -6.8%;
  top: 41%;
  z-index: 1;
  width: 36%;
  height: 49.1%;
  transform: none;
}

.hero-nav {
  position: fixed;
  /* right: max(3.125vw, calc((100vw - 1280px) / 2 + 40px)); */
  right: 30px;
  top: 40px;
  z-index: 1200;
  display: flex;
  align-items: flex-end;
  flex-direction: column;
  width: 96px;
  font-family: "sweet-sans-pro", sans-serif;
  font-size: clamp(10px, 0.94vw, 12px);
  font-weight: 800;
  line-height: 2.08;
  letter-spacing: 0;
  pointer-events: auto;
  text-align: right;
}

.hero-nav__links {
  display: grid;
  justify-items: end;
  width: 100%;
}

.hero-nav__links a {
  display: block;
  width: max-content;
  color: inherit;
  mix-blend-mode: difference;
  text-align: right;
  text-decoration: none;
  text-shadow: 0 0 1px rgba(0, 0, 0, 0.14);
}

.hero-nav-cta {
  position: relative;
  isolation: isolate;
  display: block;
  width: 64px;
  height: 362px;
  margin-top: 15px;
  overflow: visible;
  border-radius: 5px;
  background: rgba(255, 255, 255, 0.9);
  box-shadow: 0 5px 10px rgba(35, 24, 21, 0.1);
  color: #231815;
  opacity: 0;
  pointer-events: none;
  text-decoration: none;
  transform: translateY(14px);
  transition:
    opacity 0.3s ease,
    transform 0.3s ease;
}

.hero-nav.is-cta-visible .hero-nav-cta {
  opacity: 1;
  pointer-events: auto;
  transform: translateY(0);
}

.hero-nav-cta > span:first-child {
  position: absolute;
  top: 31px;
  left: 50%;
  display: block;
  width: 1em;
  color: #231815;
  font-family: "Noto Sans JP", "Hiragino Kaku Gothic ProN", "Yu Gothic", sans-serif;
  font-size: 16px;
  font-weight: 700;
  line-height: 1.06;
  letter-spacing: 0.02em;
  text-align: left;
  text-orientation: mixed;
  transform: translateX(-50%);
  white-space: nowrap;
  writing-mode: vertical-rl;
}

.hero-nav-cta strong {
  color: #eb5f20;
}

.hero-nav-cta__arrow {
  position: absolute;
  top: -32px;
  left: 37px;
  width: 90px;
  height: 63px;
  background: url("assets/hero/side-cta-arrow.svg") center / contain no-repeat;
  pointer-events: none;
}

.hero-nav a:focus-visible,
.hero-logo:focus-visible,
.hero-cta:focus-visible,
.hero-menu:focus-visible,
.sp-header-cta:focus-visible,
.sp-menu a:focus-visible,
.sp-menu__backdrop:focus-visible {
  outline: 3px solid #eb5f20;
  outline-offset: 5px;
}

.pc-concept {
  min-height: 1082px;
}

.concept {
  display: grid;
  min-height: 1082px;
  color: #fff;
  background-image:
    linear-gradient(rgba(35, 24, 21, 0.74), rgba(35, 24, 21, 0.74)),
    url("assets/concept/background.webp");
  background-attachment: fixed;
  background-position: center center;
  background-size: cover;
}

.concept-heading {
  position: absolute;
  left: 6.875%;
  top: 7.39%;
  z-index: 2;
  color: #eb5f20;
}

.concept-heading p {
  margin: 0 0 1.35em;
  font-size: clamp(13px, 1.25vw, 16px);
  font-weight: 500;
  line-height: 1.3;
}

.concept-heading h2 {
  margin: 0;
  font-family: "sweet-sans-pro", sans-serif;
  font-size: clamp(54px, 6.56vw, 84px);
  font-weight: 700;
  line-height: 0.78;
  letter-spacing: 0;
}

.concept-copy {
  position: absolute;
  left: 27.58%;
  top: 22.83%;
  z-index: 2;
  width: 44.77%;
  margin: 0;
  font-size: clamp(14px, 1.33vw, 17px);
  font-weight: 500;
  line-height: 1.8;
  letter-spacing: 0;
}

.concept-copy p {
  margin: 0 0 1.55em;
}

.concept-copy p:last-child {
  margin-bottom: 0;
}

.pc-work {
  min-height: 2470px;
  background: #eb5f20;
}

.work {
  overflow: visible;
  color: #fff;
  background: #eb5f20;
}

.work-o-stream {
  position: absolute;
  inset: 0;
  z-index: 0;
  overflow: hidden;
  pointer-events: none;
}

.work-o-stream span {
  position: absolute;
  display: block;
  width: 430px;
  aspect-ratio: 1;
  border: 88px solid rgba(255, 255, 255, 0.08);
  border-radius: 50%;
  animation: work-o-rise 32s linear infinite;
}

.work-o-stream span:nth-child(1) {
  left: -90px;
  bottom: -520px;
}

.work-o-stream span:nth-child(2) {
  right: -70px;
  bottom: -980px;
  width: 520px;
  animation-delay: -10s;
  animation-duration: 38s;
}

.work-o-stream span:nth-child(3) {
  left: 53%;
  bottom: -1380px;
  width: 380px;
  animation-delay: -22s;
  animation-duration: 44s;
}

.work-o-stream--case span:nth-child(1) {
  left: -130px;
  top: 330px;
  bottom: auto;
}

.work-o-stream--case span:nth-child(2) {
  top: 620px;
  right: -70px;
  bottom: auto;
  animation-delay: -12s;
}

.work-o-stream--case span:nth-child(3) {
  top: 980px;
  bottom: auto;
  animation-delay: -24s;
}

@keyframes work-o-rise {
  from {
    transform: translateY(0);
  }

  to {
    transform: translateY(-3200px);
  }
}

.work-marquee {
  position: fixed;
  left: 50%;
  bottom: 22px;
  z-index: 2;
  width: min(100vw, 1280px);
  overflow: hidden;
  pointer-events: none;
  opacity: 0;
  transform: translateX(-50%);
  transition: opacity 0.3s ease;
}

.work.is-active .work-marquee,
.case.is-active .work-marquee {
  opacity: 1;
}

.page.is-case-active .work > .work-marquee {
  opacity: 0;
}

.work-marquee__track {
  display: flex;
  width: max-content;
  animation: work-marquee 60s linear infinite;
}

.work-marquee span {
  flex: 0 0 auto;
  padding-right: 0.6em;
  color: rgba(255, 255, 255, 0.14);
  font-size: 120px;
  font-weight: 700;
  line-height: 1;
  white-space: nowrap;
}

@keyframes work-marquee {
  from {
    transform: translateX(0);
  }

  to {
    transform: translateX(-50%);
  }
}

.work-layout {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: 360px 722px;
  column-gap: 66px;
  width: 1104px;
  margin: 0 auto;
  padding: 80px 0 118px;
}

.work-sticky {
  position: sticky;
  top: 110px;
  align-self: start;
  min-height: 650px;
}

.section-kicker {
  margin: 0 0 18px;
  font-size: 16px;
  font-weight: 700;
  line-height: 1.3;
}

.work-sticky h2 {
  margin: 0;
  font-family: "sweet-sans-pro", sans-serif;
  font-size: 84px;
  font-weight: 700;
  line-height: 0.8;
  letter-spacing: 0;
}

.work-portrait {
  display: block;
  width: 240px;
  height: auto;
  margin: 60px 0 0 0;
}

.work-main {
  min-width: 0;
}

.work-intro {
  padding-top: 69px;
}

.work-intro__eyebrow {
  margin: 0;
  padding: 18px 0;
  border-top: 1px solid rgba(255, 255, 255, 0.86);
  border-bottom: 1px solid rgba(255, 255, 255, 0.86);
  font-size: 19px;
  font-weight: 700;
  line-height: 1.5;
}

.work-intro__lead {
  margin: 40px 0 48px;
  font-size: 36px;
  font-weight: 700;
  line-height: 1.48;
}

.work-card-list {
  display: grid;
  gap: 30px;
}

.work-card {
  background: #f4ede8;
  color: #231815;
  padding: 38px 49px 44px;
}

.work-card__num {
  margin: 0 0 14px;
  color: #eb5f20;
  font-size: 17px;
  font-weight: 700;
  line-height: 1;
}

.work-card h3 {
  margin: 0 0 28px;
  color: #eb5f20;
  font-size: 30px;
  font-weight: 700;
  line-height: 1.3;
}

.work-card__lead {
  margin: 0;
  font-size: 16px;
  font-weight: 500;
  line-height: 1.75;
}

.work-logo-block {
  display: flex;
  align-items: center;
  width: 480px;
  max-width: 100%;
  margin: 22px 0 20px;
}

.work-logo-block img {
  display: block;
  width: 100%;
  height: auto;
}

.work-card ul {
  margin: 30px 0 0;
  padding: 28px 0 0;
  border-top: 1px solid #eb5f20;
  list-style: none;
}

.work-card li {
  position: relative;
  margin: 0 0 10px;
  padding-left: 1.05em;
  font-size: 16px;
  font-weight: 700;
  line-height: 1.45;
}

.work-card li::before {
  position: absolute;
  left: 0;
  top: 0.57em;
  width: 0.45em;
  height: 0.45em;
  background: #231815;
  content: "";
}

.work-reasons {
  margin-top: 68px;
  text-align: center;
}

.work-reasons__kicker {
  margin: 0 0 24px;
  color: #fff;
  font-size: 16px;
  font-weight: 700;
}

.work-reason-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
}

.work-reason-grid article {
  min-height: 154px;
  padding: 24px 18px;
  border: 1px solid rgba(255, 255, 255, 0.72);
  color: #fff;
}

.work-reason-grid h3 {
  margin: 0 0 13px;
  font-size: 16px;
  font-weight: 700;
  line-height: 1.35;
}

.work-reason-grid p {
  margin: 0;
  font-size: 12px;
  font-weight: 500;
  line-height: 1.65;
}

.work-reason__num {
  margin: 0;
}

.case {
  isolation: isolate;
  padding: 132px 0 146px;
  background: #eb5f20;
  color: #231815;
}

.case::before {
  position: absolute;
  inset: 0;
  z-index: -2;
  background: #ff8b23;
  clip-path: polygon(0 14%, 100% 4%, 100% 100%, 0 100%);
  content: "";
}

.case-inner {
  position: relative;
  z-index: 1;
  width: 1104px;
  margin: 0 auto;
}

.case-heading {
  margin: 0 0 52px;
  color: #fff;
  text-align: center;
}

.case-heading h2 {
  margin: 0 0 36px;
  font-family: "sweet-sans-pro", sans-serif;
  font-size: 90px;
  font-weight: 700;
  line-height: 1;
}

.case-heading__lead {
  margin: 0;
  font-size: 32px;
  font-weight: 500;
  line-height: 1.5;
}

.case-heading__note {
  width: 720px;
  margin: 36px auto 0;
  color: rgba(255, 255, 255, 0.9);
  font-size: 17px;
  font-weight: 400;
  line-height: 1.8;
}

.case-list {
  display: grid;
  gap: 20px;
}

.case-card {
  padding: 50px;
  background: #f4ede8;
}

.case-card summary {
  list-style: none;
}

.case-card summary::-webkit-details-marker {
  display: none;
}

.case-card__summary {
  position: relative;
  display: block;
  padding-right: 88px;
  cursor: pointer;
}

.case-card__summary:focus-visible {
  outline: 3px solid #eb5f20;
  outline-offset: 7px;
}

.case-card__title,
.case-card__subtitle,
.case-card__lead {
  margin: 0;
}

.case-card__title {
  color: #231815;
  font-size: 20px;
  font-weight: 500;
  line-height: 1.5;
  letter-spacing: 0.06em;
}

.case-card__title span,
.case-highlight {
  color: #eb5f20;
}

.case-card__title span {
  font-weight: 700;
}

.case-card__subtitle {
  font-size: 20px;
  font-weight: 500;
  line-height: 1.5;
  letter-spacing: 0.06em;
}

.case-card__lead {
  margin-top: 25px;
  font-size: 16px;
  font-weight: 400;
  line-height: 1.5;
  letter-spacing: 0.06em;
}

.case-toggle {
  position: absolute;
  right: 0;
  top: 30px;
  width: 38px;
  height: 38px;
  border-radius: 50%;
  background: #eb5f20;
}

.case-toggle::before,
.case-toggle::after {
  position: absolute;
  left: 50%;
  top: 50%;
  width: 15px;
  height: 3px;
  border-radius: 999px;
  background: #fff;
  content: "";
  transform: translate(-50%, -50%);
  transition: transform 0.25s ease;
}

.case-toggle::after {
  transform: translate(-50%, -50%) rotate(90deg);
}

.case-card[open] .case-toggle::after {
  transform: translate(-50%, -50%) rotate(0deg);
}

.case-table-wrap {
  margin-top: 28px;
}

.case-table {
  width: 100%;
  border-collapse: collapse;
  table-layout: fixed;
  background: #fff;
  font-size: 15px;
  font-weight: 400;
  line-height: 1.5;
  letter-spacing: 0.06em;
}

.case-table__stage {
  width: 25%;
}

.case-table th {
  padding: 15px 30px 16px;
  border: 1px solid #f4ede8;
  background: #eb5f20;
  color: #fff;
  font-size: 16px;
  font-weight: 500;
  line-height: 1.3;
  text-align: left;
}

.case-table td {
  padding: 30px 30px 20px;
  border: 1px solid #eadfd8;
  background: #fff;
  vertical-align: middle;
}

.case-table td:first-child {
  font-size: 16px;
  font-weight: 500;
  line-height: 1.3;
  text-align: left;
}

.case-table__row--strategy td {
  background: #f3e2dc;
}

.case-table p {
  margin: 0;
}

.case-table p:last-child {
  margin-bottom: 0;
}

.case-results {
  margin: 0;
  padding-left: 1.4em;
  font-weight: 700;
  line-height: 1.5;
}

.case-bullet-list,
.case-bullet-list ul {
  margin: 0;
  padding-left: 1.3em;
}

.case-bullet-list > li {
  margin-bottom: 0.9em;
}

.case-bullet-list > li:last-child {
  margin-bottom: 0;
}

.case-bullet-list li {
  padding-left: 0.1em;
}

.case .work-reasons {
  margin-top: 90px;
  color: #fff;
  text-align: center;
}

.case .work-reasons__kicker {
  margin: 0 0 51px;
  color: #fff;
  font-size: 32px;
  font-weight: 500;
  line-height: 1.5;
}

.case .work-reason-grid {
  grid-template-columns: repeat(3, 340px);
  gap: 42px;
  justify-content: center;
}

.case .work-reason-grid article {
  min-height: 379px;
  padding: 37px 30px 38px;
  border: 1px solid rgba(255, 255, 255, 0.9);
  color: #fff;
}

.case .work-reason__num {
  margin: 0 0 35px;
  font-family: "sweet-sans-pro", sans-serif;
  font-size: 18px;
  font-weight: 700;
  line-height: 1.3;
}

.case .work-reason-grid h3 {
  margin: 0 0 17px;
  font-size: 32px;
  font-weight: 700;
  line-height: 1.5;
}

.case .work-reason-grid h3 span {
  display: block;
  font-size: 18px;
}

.case .work-reason-grid p:not(.work-reason__num) {
  margin: 0;
  font-size: 16px;
  font-weight: 500;
  line-height: 1.5;
  letter-spacing: 0.06em;
  text-align: left;
}

.approach {
  overflow: visible;
  background: #f4ece5;
  color: #231815;
}

.pc-approach {
  padding: 84px 0 96px;
}

.approach-inner {
  width: 1104px;
  margin: 0 auto;
}

.approach-heading {
  margin: 0 0 96px;
  color: #eb5f20;
  text-align: center;
}

.approach-heading__kicker {
  margin: 0 0 14px;
  font-size: 16px;
  font-weight: 500;
  line-height: 1.3;
  letter-spacing: 0.06em;
}

.approach-heading h2 {
  margin: 0 0 42px;
  font-family: "sweet-sans-pro", sans-serif;
  font-size: 84px;
  font-weight: 700;
  line-height: 1.3;
}

.approach-heading__copy {
  color: #231815;
  font-size: 17px;
  font-weight: 400;
  line-height: 1.8;
  letter-spacing: 0.06em;
}

.approach-heading__copy p {
  margin: 0 0 28px;
}

.approach-heading__copy p:last-child {
  margin-bottom: 0;
}

.approach-stack {
  display: grid;
  gap: 50px;
  padding-bottom: 0;
}

.approach-card {
  --stack-offset: 0px;
  position: sticky;
  top: calc(92px + var(--stack-offset));
  z-index: 1;
  display: grid;
  grid-template-columns: 552px 552px;
  min-height: 391px;
  background: #fff;
  box-shadow: 0 22px 42px rgba(35, 24, 21, 0.08);
}

.approach-card:nth-child(2) {
  --stack-offset: 18px;
  z-index: 2;
}

.approach-card:nth-child(3) {
  --stack-offset: 36px;
  z-index: 3;
}

.approach-card:nth-child(4) {
  --stack-offset: 54px;
  z-index: 4;
}

.approach-card--grow {
  min-height: 460px;
}

.approach-card__body {
  position: relative;
  padding: 40px 0 40px 50px;
  overflow: hidden;
}

.approach-card__body::after {
  position: absolute;
  left: 120px;
  top: 56px;
  z-index: 0;
  width: 437px;
  height: 247px;
  background: url("assets/approach/arrow.svg") center / contain no-repeat;
  content: "";
  transform: rotate(-5deg);
}

.approach-card__body > * {
  position: relative;
  z-index: 1;
}

.approach-card__num {
  margin: 0 0 9px;
  color: #eb5f20;
  font-family: "sweet-sans-pro", sans-serif;
  font-size: 18px;
  font-weight: 700;
  line-height: 1.3;
}

.approach-card h3 {
  margin: 0;
  color: #eb5f20;
  font-family: "sweet-sans-pro", sans-serif;
  font-size: 52px;
  font-weight: 700;
  line-height: 1.3;
}

.approach-card__label {
  margin: 0 0 25px;
  font-size: 28px;
  font-weight: 500;
  line-height: 1.3;
  letter-spacing: 0.06em;
}

.approach-card--grow .approach-card__label {
  margin-bottom: 25px;
  line-height: 1.5;
}

.approach-card__text {
  width: 442px;
  margin: 0;
  font-size: 16px;
  font-weight: 400;
  line-height: 1.5;
  letter-spacing: 0.06em;
}

.approach-card__note {
  width: 432px;
  margin: 18px 0 0;
  font-size: 12px;
  font-weight: 400;
  line-height: 1.5;
}

.approach-card__image {
  width: 552px;
  height: 331px;
  margin: 0;
  overflow: hidden;
}

.approach-card--grow .approach-card__image {
  height: 368px;
}

.approach-card__image img {
  display: block;
  width: 100%;
  height: 100%;
  max-width: none;
  object-fit: cover;
  user-select: none;
}

.approach-card:first-child .approach-card__image img {
  object-position: center center;
}

.approach-card:nth-child(2) .approach-card__image img {
  object-position: center center;
}

.approach-card:nth-child(3) .approach-card__image img {
  object-position: center center;
}

.approach-card--grow .approach-card__image img {
  object-position: center center;
}

.journal {
  background: #fff;
  color: #231815;
}

.pc-journal {
  display: flex;
  min-height: min(65.625vw, 840px);
  padding: min(6.1vw, 78px) min(6.875vw, 88px) min(6.25vw, 80px);
  flex-direction: column;
  background: #fff;
}

.journal-heading p {
  margin: 0;
  color: #eb5f20;
  font-size: clamp(12px, 1.25vw, 16px);
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: 0.04em;
}

.journal-heading h2 {
  margin: 8px 0 0;
  color: #eb5f20;
  font-family: "sweet-sans-pro", sans-serif;
  font-size: clamp(48px, 5.7vw, 73px);
  font-weight: 900;
  line-height: 1;
  letter-spacing: 0.035em;
}

.journal-list {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: min(3.28vw, 42px);
  margin-top: min(4.77vw, 61px);
}

.journal-card {
  display: block;
  color: inherit;
  text-decoration: none;
}

.journal-card__thumb {
  position: relative;
  width: 100%;
  aspect-ratio: 340 / 227;
  margin: 0;
  overflow: hidden;
  background: #c9c9c9;
}

.journal-card__thumb img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.5s ease;
}

.journal-card:hover .journal-card__thumb img,
.journal-card:focus-visible .journal-card__thumb img {
  transform: scale(1.045);
}

.journal-card__date {
  display: block;
  margin-top: min(1.56vw, 20px);
  color: #9e9e9e;
  font-family: "sweet-sans-pro", sans-serif;
  font-size: clamp(12px, 1.17vw, 15px);
  font-weight: 900;
  line-height: 1.4;
  letter-spacing: 0.08em;
}

.journal-card h3 {
  margin: min(1.72vw, 22px) 0 0;
  font-size: clamp(16px, 1.56vw, 20px);
  font-weight: 800;
  line-height: 1.52;
  letter-spacing: 0.03em;
}

.journal-more {
  display: flex;
  align-items: center;
  align-self: flex-end;
  gap: min(1.72vw, 22px);
  margin-top: auto;
  color: #231815;
  font-family: "sweet-sans-pro", sans-serif;
  font-size: clamp(13px, 1.25vw, 16px);
  font-weight: 900;
  line-height: 1;
  letter-spacing: 0.02em;
  text-decoration: none;
}

.journal-more__circle {
  position: relative;
  display: block;
  width: min(5.7vw, 73px);
  height: min(5.7vw, 73px);
  min-width: 52px;
  min-height: 52px;
  border: 1.4px solid currentColor;
  border-radius: 999px;
  transition:
    background 0.28s ease,
    color 0.28s ease;
}

.journal-more__circle::before,
.journal-more__circle::after {
  position: absolute;
  top: 50%;
  left: 50%;
  content: "";
  background: currentColor;
  transform-origin: center;
}

.journal-more__circle::before {
  width: 23px;
  height: 2px;
  transform: translate(-50%, -50%);
}

.journal-more__circle::after {
  width: 12px;
  height: 12px;
  border-top: 2px solid currentColor;
  border-right: 2px solid currentColor;
  background: transparent;
  transform: translate(calc(-50% + 5px), -50%) rotate(45deg);
}

.journal-more:hover .journal-more__circle,
.journal-more:focus-visible .journal-more__circle {
  background: #231815;
  color: #fff;
}

.company {
  background: #f4f4f4;
  color: #231815;
}

.pc-company {
  min-height: min(75.39vw, 965px);
  padding: min(6.1vw, 78px) min(6.875vw, 88px) min(8.4vw, 108px);
  background: #f4f4f4;
}

.company-heading p {
  margin: 0;
  color: #eb5f20;
  font-size: clamp(12px, 1.25vw, 16px);
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: 0.04em;
}

.company-heading h2 {
  margin: 10px 0 0;
  color: #eb5f20;
  font-family: "sweet-sans-pro", sans-serif;
  font-size: clamp(48px, 5.86vw, 75px);
  font-weight: 900;
  line-height: 1;
  letter-spacing: 0.04em;
}

.company-layout {
  display: grid;
  grid-template-columns: min(25vw, 320px) minmax(0, min(56.4vw, 722px));
  gap: min(4.84vw, 62px);
  align-items: start;
  margin-top: min(4.3vw, 55px);
}

.company-portrait {
  width: min(18.6vw, 238px);
  aspect-ratio: 1;
  margin: 0 0 0 min(2.5vw, 32px);
  overflow: hidden;
  border-radius: 50%;
}

.company--pc .company-portrait {
  transform: translateY(-7px);
}

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

.company-table {
  width: 100%;
  margin: 0;
}

.company-row {
  display: grid;
  grid-template-columns: min(12.5vw, 160px) minmax(0, 1fr);
  padding: min(1.56vw, 20px) 0 min(1.4vw, 18px);
  border-bottom: 2px dotted #cfcfcf;
}

.company-row:first-child {
  padding-top: 0;
  padding-bottom: min(1.56vw, 20px);
}

.company-row dt,
.company-row dd {
  margin: 0;
  font-size: clamp(13px, 1.25vw, 16px);
  line-height: 1.85;
  letter-spacing: 0.04em;
}

.company-row dt {
  font-weight: 800;
}

.company-row dd {
  font-weight: 500;
}

.company-row p {
  margin: 0;
}

.company-row--business dd {
  position: relative;
}

.company-row ul {
  margin: 0;
  padding: 0;
  list-style: none;
}

.company-row li {
  position: relative;
  padding-left: 1.1em;
}

.company-row li::before {
  position: absolute;
  top: 0;
  left: 0;
  content: "・";
}

.company-lstep {
  display: flex;
  align-items: center;
  justify-content: center;
  width: min(12.1vw, 155px);
  height: min(5.47vw, 70px);
  border-radius: 5px;
  background: #fff;
}

.company--pc .company-lstep {
  position: absolute;
  right: min(6.15vw, 79px);
  top: min(4.45vw, 57px);
}

.company-lstep img {
  display: block;
  width: 80%;
  height: auto;
}

.who {
  --who-orange: #eb5f20;
  --who-cream: #f4ede8;
  background: #fff;
  color: #231815;
}

.who img {
  display: block;
}

.pc-who {
  background: #fff;
}

.pc-who .who-intro {
  position: relative;
  min-height: min(137.9vw, 1765px);
  background: #fff;
}

.pc-who .who-hero {
  position: absolute;
  inset: 0;
}

.who-title {
  margin: 0;
  color: var(--who-orange);
  font-family: "sweet-sans-pro", sans-serif;
  font-weight: 900;
  line-height: 0.9;
  letter-spacing: 0.03em;
}

.pc-who .who-title {
  position: absolute;
  left: min(5.3vw, 68px);
  top: min(5.2vw, 67px);
  z-index: 2;
  font-size: clamp(78px, 9.7vw, 124px);
  transform: rotate(-5deg);
}

.who-hello {
  overflow: hidden;
  border-radius: 50%;
}

.who-hello img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.pc-who .who-hello {
  position: absolute;
  left: min(12.4vw, 159px);
  top: min(17.2vw, 220px);
  z-index: 1;
  width: min(17.8vw, 228px);
  height: min(17.8vw, 228px);
  margin: 0;
  background: var(--who-cream);
}

.who-kicker,
.who-name {
  margin: 0;
}

.pc-who .who-kicker {
  position: absolute;
  left: min(33.4vw, 428px);
  top: min(20.5vw, 262px);
  font-size: clamp(18px, 2.2vw, 28px);
  font-weight: 800;
  line-height: 1.4;
}

.who-name span {
  color: var(--who-orange);
  font-weight: 800;
  line-height: 1.15;
}

.who-name strong {
  color: var(--who-orange);
  font-weight: 900;
  letter-spacing: 0.04em;
}

.who-name em {
  color: #231815;
  font-style: normal;
  font-weight: 900;
}

.pc-who .who-name {
  position: absolute;
  left: min(33.3vw, 426px);
  top: min(26.1vw, 334px);
  display: flex;
  align-items: flex-end;
  gap: min(2.5vw, 32px);
}

.pc-who .who-name span {
  font-size: clamp(20px, 2.6vw, 33px);
}

.pc-who .who-name strong {
  font-size: clamp(52px, 6.2vw, 79px);
  line-height: 0.86;
}

.pc-who .who-name em {
  font-size: clamp(42px, 5vw, 64px);
  transform: rotate(-18deg);
}

.who-swoosh {
  position: absolute;
  pointer-events: none;
}

.pc-who .who-swoosh {
  left: min(54.5vw, 698px);
  top: min(42.2vw, 540px);
  width: min(24vw, 307px);
  height: min(7.8vw, 100px);
  border-bottom: min(0.55vw, 7px) solid rgba(224, 184, 154, 0.35);
  border-left: min(0.35vw, 4px) solid rgba(224, 184, 154, 0.35);
  transform: rotate(-18deg) skewX(-28deg);
}

.pc-who .who-story {
  position: absolute;
  left: min(6.9vw, 88px);
  top: min(45.7vw, 585px);
  width: min(43.4vw, 556px);
}

.who-story h3 {
  margin: 0;
  font-weight: 900;
  letter-spacing: 0.06em;
}

.pc-who .who-story h3 {
  margin-bottom: min(3.2vw, 41px);
  font-size: clamp(24px, 2.9vw, 37px);
  line-height: 1.52;
}

.who-story p {
  margin: 0;
  font-weight: 500;
  letter-spacing: 0.04em;
}

.pc-who .who-story p {
  font-size: clamp(11px, 1.1vw, 14px);
  line-height: 1.72;
}

.pc-who .who-story p + p {
  margin-top: min(1.55vw, 20px);
}

.who-story small {
  font-size: 0.82em;
}

.who-profile {
  margin: 0;
}

.pc-who .who-profile {
  position: absolute;
  left: min(58.6vw, 750px);
  top: min(53vw, 678px);
  width: min(28.1vw, 360px);
}

.who-profile > img {
  width: 100%;
  height: auto;
}

.who-profile figcaption {
  text-align: center;
}

.pc-who .who-profile figcaption {
  margin-top: min(2.2vw, 28px);
}

.who-profile figcaption span,
.who-profile figcaption small {
  display: block;
  font-weight: 800;
}

.who-profile figcaption strong {
  display: block;
  font-weight: 900;
  letter-spacing: 0.08em;
}

.pc-who .who-profile figcaption span {
  font-size: clamp(11px, 1.02vw, 13px);
  line-height: 1.6;
}

.pc-who .who-profile figcaption strong {
  margin-top: 4px;
  font-size: clamp(18px, 1.72vw, 22px);
  line-height: 1.5;
}

.pc-who .who-profile figcaption small {
  margin-top: 2px;
  font-size: clamp(9px, 0.78vw, 10px);
  letter-spacing: 0.08em;
}

.who-photo {
  position: absolute;
  object-fit: cover;
}

.pc-who .who-photo--laptop {
  right: min(7.1vw, 91px);
  top: min(113.2vw, 1449px);
  width: min(15.4vw, 197px);
  height: min(13.2vw, 169px);
}

.pc-who .who-photo--whiteboard {
  left: min(58.6vw, 750px);
  top: min(126.7vw, 1622px);
  width: min(15.7vw, 201px);
  height: min(13.5vw, 173px);
}

.who-career {
  position: relative;
  background: var(--who-cream);
}

.pc-who .who-career {
  min-height: min(46.5vw, 595px);
}

.pc-who .who-career::before {
  position: absolute;
  right: 0;
  bottom: 100%;
  left: 0;
  height: min(15.6vw, 200px);
  background: var(--who-cream);
  clip-path: polygon(0 100%, 100% 0, 100% 100%);
  content: "";
}

.who-career__label {
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--who-orange);
  color: #fff;
  font-weight: 900;
  letter-spacing: 0.04em;
}

.pc-who .who-career__label {
  position: absolute;
  left: min(6.9vw, 88px);
  top: max(-4.9vw, -63px);
  z-index: 2;
  width: min(19.2vw, 246px);
  height: min(6vw, 77px);
  font-size: clamp(18px, 1.95vw, 25px);
}

.pc-who .who-career__inner {
  position: relative;
  height: min(46.5vw, 595px);
}

.who-career-block {
  position: absolute;
}

.who-career-block h3,
.who-current h3 {
  margin: 0;
  color: var(--who-orange);
  font-weight: 900;
  letter-spacing: 0.06em;
}

.who-career-block h3 span {
  font-size: 0.66em;
}

.who-career-block ul,
.who-current ul {
  margin: 0;
  padding: 0;
  list-style: none;
}

.who-career-block li,
.who-current li {
  position: relative;
  padding-left: 1em;
}

.who-career-block li::before,
.who-current li::before {
  position: absolute;
  left: 0;
  content: "■";
}

.pc-who .who-career-block ul,
.pc-who .who-career-block p {
  margin-top: min(1.25vw, 16px);
  font-size: clamp(10px, 0.98vw, 12.5px);
  font-weight: 800;
  line-height: 1.7;
  letter-spacing: 0.04em;
}

.pc-who .who-career-block--company {
  left: min(6.9vw, 88px);
  top: min(7vw, 90px);
  width: min(38vw, 486px);
}

.pc-who .who-career-block--company h3,
.pc-who .who-career-block--brand h3,
.pc-who .who-career-block--challenge h3,
.pc-who .who-career-block--result h3 {
  font-size: clamp(38px, 4.9vw, 63px);
  line-height: 1.06;
}

.pc-who .who-career-block--brand {
  left: min(6.9vw, 88px);
  top: min(27.7vw, 354px);
  width: min(43vw, 550px);
}

.pc-who .who-career-block--brand img {
  position: absolute;
  right: min(1.2vw, 15px);
  top: min(2.3vw, 30px);
  width: min(13.2vw, 169px);
  border-radius: 50%;
}

.pc-who .who-career-block--people {
  left: min(58.2vw, 745px);
  top: min(8.6vw, 110px);
}

.pc-who .who-career-block--people h3 {
  font-size: clamp(44px, 5.8vw, 74px);
  line-height: 1.05;
  writing-mode: vertical-rl;
}

.pc-who .who-career-block--people p {
  position: absolute;
  left: min(-5vw, -64px);
  top: min(18vw, 230px);
  margin: 0;
  white-space: nowrap;
  writing-mode: vertical-rl;
}

.pc-who .who-career-block--challenge {
  left: min(74vw, 947px);
  top: min(6.6vw, 84px);
  width: min(27vw, 346px);
}

.pc-who .who-career-block--challenge ul {
  margin-top: min(1.4vw, 18px);
  width: min(23vw, 294px);
}

.pc-who .who-career-arrow {
  position: absolute;
  right: min(14.6vw, 187px);
  top: min(27.2vw, 348px);
  color: var(--who-orange);
  font-size: clamp(64px, 8.2vw, 105px);
  font-weight: 900;
  line-height: 0.8;
}

.pc-who .who-career-block--result {
  right: min(6.4vw, 82px);
  bottom: min(1.9vw, 24px);
  width: min(36vw, 461px);
}

.who-current {
  position: relative;
  overflow: hidden;
  background: var(--who-orange);
  color: #fff;
}

.pc-who .who-current {
  min-height: min(36.2vw, 464px);
}

.who-current h3,
.who-current-main h3,
.who-ai h3,
.who-local h3 {
  color: #fff;
}

.pc-who .who-award {
  position: absolute;
  left: min(8.3vw, 106px);
  top: min(3.6vw, 46px);
  width: min(24vw, 307px);
}

.pc-who .who-award h3 {
  font-size: clamp(48px, 5.15vw, 66px);
  line-height: 1.05;
  writing-mode: vertical-rl;
}

.pc-who .who-award p {
  position: absolute;
  left: max(-5vw, -64px);
  top: min(2.3vw, 30px);
  margin: 0;
  font-size: clamp(10px, 0.94vw, 12px);
  font-weight: 800;
  line-height: 1.65;
  letter-spacing: 0.06em;
  writing-mode: vertical-rl;
}

.who-current__logo {
  display: flex;
  align-items: center;
  justify-content: center;
  background: #fff;
  border-radius: 5px;
}

.pc-who .who-current__logo {
  width: min(12.1vw, 155px);
  height: min(5.47vw, 70px);
  margin-top: min(2.2vw, 28px);
}

.who-current__logo img {
  width: 80%;
  height: auto;
}

.pc-who .who-current-main {
  position: absolute;
  left: min(33.5vw, 429px);
  top: min(5.1vw, 65px);
  width: min(41vw, 525px);
}

.pc-who .who-current-main h3 {
  font-size: clamp(42px, 4.9vw, 63px);
  line-height: 1.05;
}

.pc-who .who-current-main h3 span {
  font-size: 0.36em;
}

.pc-who .who-current-main ul {
  display: grid;
  grid-template-columns: 1.2fr 1fr;
  gap: 0 min(1.6vw, 20px);
  margin-top: min(2vw, 26px);
  font-size: clamp(10px, 1.02vw, 13px);
  font-weight: 800;
  line-height: 1.65;
}

.pc-who .who-current__meeting {
  position: absolute;
  right: min(8.2vw, 105px);
  top: max(-3.4vw, -44px);
  width: min(16.8vw, 215px);
  height: min(16.8vw, 215px);
  margin: 0;
  overflow: hidden;
  border-radius: 50%;
}

.who-current__meeting img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.pc-who .who-ai {
  position: absolute;
  right: min(6.4vw, 82px);
  top: min(18.5vw, 237px);
  text-align: right;
}

.pc-who .who-ai h3 {
  font-size: clamp(52px, 6.2vw, 79px);
  line-height: 0.9;
}

.pc-who .who-ai p {
  margin: min(0.8vw, 10px) 0 0;
  font-size: clamp(10px, 0.95vw, 12px);
  font-weight: 800;
  line-height: 1.45;
  writing-mode: vertical-rl;
}

.pc-who .who-local {
  position: absolute;
  left: min(55.4vw, 709px);
  bottom: min(2.1vw, 27px);
  width: min(34vw, 435px);
}

.pc-who .who-local h3 {
  font-size: clamp(46px, 5.9vw, 75px);
  line-height: 1;
}

.pc-who .who-local p {
  margin: min(0.9vw, 12px) 0 0;
  font-size: clamp(18px, 2.1vw, 27px);
  font-weight: 900;
  line-height: 1.28;
}

.pc-who .who-local ul {
  margin-top: min(1.4vw, 18px);
  font-size: clamp(10px, 1vw, 13px);
  font-weight: 800;
  line-height: 1.55;
}

.who-map {
  display: flex;
  align-items: center;
  justify-content: center;
  width: min(10vw, 128px);
  height: min(9.1vw, 116px);
  background: #9bd07a;
  color: #57874b;
  font-family: "sweet-sans-pro", sans-serif;
  font-size: clamp(8px, 0.82vw, 10px);
  font-weight: 900;
  clip-path: polygon(22% 5%, 48% 18%, 72% 6%, 88% 28%, 80% 52%, 96% 77%, 66% 87%, 54% 100%, 35% 85%, 8% 90%, 17% 62%, 0 38%);
}

.pc-who .who-map {
  position: absolute;
  right: max(-3vw, -38px);
  top: min(4.2vw, 54px);
  transform: rotate(-12deg);
}

.pc-who .who-local img {
  position: absolute;
  right: min(7.8vw, 100px);
  bottom: max(-1vw, -13px);
  width: min(22.7vw, 290px);
  height: min(16.4vw, 210px);
  object-fit: cover;
  border-radius: 6px;
}

.pc-contact {
  aspect-ratio: 1280 / 891;
  background: #ece6e1;
}

.pc-footer {
  aspect-ratio: 1280 / 259;
  background: #231815;
}

.contact-form {
  position: absolute;
  inset: 0;
}

.contact-field,
.contact-submit {
  position: absolute;
  appearance: none;
  border: 0;
  background: transparent;
  color: #231815;
  font-family: inherit;
}

.contact-field {
  padding: 0 2.35%;
  border-radius: 6px;
  font-size: clamp(13px, 1.56vw, 20px);
  line-height: 1;
}

.contact-field:focus-visible,
.contact-submit:focus-visible {
  outline: 3px solid #eb5f20;
  outline-offset: 4px;
}

.contact-submit {
  cursor: pointer;
  border-radius: 999px;
}

.contact-form--pc .contact-field--name {
  left: 44.61%;
  top: 33.22%;
  width: 48.44%;
  height: 6.73%;
}

.contact-form--pc .contact-field--email {
  left: 44.61%;
  top: 49.05%;
  width: 48.44%;
  height: 6.73%;
}

.contact-form--pc .contact-field--url {
  left: 44.61%;
  top: 64.87%;
  width: 48.44%;
  height: 6.62%;
}

.contact-form--pc .contact-submit {
  left: 44.69%;
  top: 79.46%;
  width: 27.81%;
  height: 8.31%;
}

@media (max-width: 767px) {
  .hero-nav,
  .page--pc {
    display: none;
  }

  .page--sp {
    display: block;
    width: 100vw;
  }

  .sp-header {
    position: fixed;
    z-index: 1000;
    top: 0;
    left: 0;
    display: block;
    width: 100%;
    height: 13.33vw;
    /* min-height: 56px; */
    background: transparent;
    pointer-events: none;
    transition: background-color 0.28s ease;
  }

  .page--sp.is-sp-header-scrolled .sp-header {
    background: #f4ece5;
  }

  .sp-hero {
    aspect-ratio: 750 / 1334;
    background: #f2ebe5;
  }

  .sp-header .hero-logo {
    position: absolute;
    z-index: 1002;
    left: 4vw;
    top: 2.67vw;
    width: 34.06vw;
    pointer-events: auto;
  }

  .sp-header .hero-menu {
    position: absolute;
    right: 4vw;
    top: 4.53vw;
    z-index: 1002;
    width: 8vw;
    height: 4.27vw;
    padding: 0;
    border: 0;
    background: transparent;
    color: #1e1e1e;
    pointer-events: auto;
  }

  .sp-header .sp-header-cta {
    position: absolute;
    z-index: 1001;
    left: 48.67vw;
    top: 2.67vw;
    display: flex;
    flex-direction: column;
    justify-content: center;
    width: 35.33vw;
    height: 8vw;
    border-radius: 1.33vw;
    background: #eb5f20;
    color: #fff;
    font-size: 2.4vw;
    font-weight: 500;
    line-height: 1.33;
    letter-spacing: 0.04em;
    text-align: center;
    text-decoration: none;
    opacity: 0;
    pointer-events: none;
    transform: translateY(-1.6vw);
    transition:
      opacity 0.28s ease,
      transform 0.28s ease;
  }

  .page--sp.is-sp-header-scrolled .sp-header-cta {
    opacity: 1;
    pointer-events: auto;
    transform: translateY(0);
  }

  .sp-header .hero-menu span {
    position: absolute;
    left: 0;
    width: 100%;
    height: max(2px, 0.53vw);
    background: currentColor;
    transform-origin: center;
    transition:
      opacity 0.24s ease,
      top 0.24s ease,
      bottom 0.24s ease,
      width 0.24s ease,
      transform 0.24s ease;
  }

  .sp-header .hero-menu span:first-child {
    top: 0;
    width: 43.33%;
  }

  .sp-header .hero-menu span:nth-child(2) {
    top: 50%;
    transform: translateY(-50%);
  }

  .sp-header .hero-menu span:last-child {
    bottom: 0;
  }

  .page--sp.is-sp-menu-open .sp-header {
    background: #f4ece5;
  }

  .page--sp.is-sp-menu-open .hero-menu span:first-child {
    top: 50%;
    width: 100%;
    transform: translateY(-50%) rotate(32deg);
  }

  .page--sp.is-sp-menu-open .hero-menu span:nth-child(2) {
    opacity: 0;
    transform: translateY(-50%) scaleX(0.35);
  }

  .page--sp.is-sp-menu-open .hero-menu span:last-child {
    bottom: 50%;
    transform: translateY(50%) rotate(-32deg);
  }

  body.is-sp-menu-open {
    overflow: hidden;
  }

  .sp-menu {
    position: fixed;
    inset: 0;
    z-index: 999;
    display: block;
    pointer-events: none;
  }

  .sp-menu__backdrop {
    position: absolute;
    inset: 0;
    display: block;
    width: 100%;
    height: 100%;
    padding: 0;
    border: 0;
    appearance: none;
    background: rgba(35, 24, 21, 0.34);
    cursor: pointer;
    opacity: 0;
    transition: opacity 0.3s ease;
  }

  .sp-menu__panel {
    position: absolute;
    top: 0;
    right: 0;
    width: min(76vw, 360px);
    height: 100vh;
    height: 100dvh;
    padding: max(94px, 22vw) 6.67vw 9.6vw;
    background: #f4ece5;
    box-shadow: -18px 0 36px rgba(35, 24, 21, 0.14);
    color: #231815;
    pointer-events: auto;
    transform: translateX(102%);
    transition: transform 0.36s cubic-bezier(0.22, 1, 0.36, 1);
  }

  .page--sp.is-sp-menu-open .sp-menu {
    pointer-events: auto;
  }

  .page--sp.is-sp-menu-open .sp-menu__backdrop {
    opacity: 1;
  }

  .page--sp.is-sp-menu-open .sp-menu__panel {
    transform: translateX(0);
  }

  .sp-menu__nav {
    display: grid;
    gap: 3.33vw;
    justify-items: end;
    font-family: "sweet-sans-pro", sans-serif;
    font-size: clamp(26px, 8vw, 42px);
    font-weight: 800;
    line-height: 0.98;
    letter-spacing: 0.01em;
    text-align: right;
  }

  .sp-menu__nav a {
    color: currentColor;
    text-decoration: none;
  }

  .sp-menu__cta {
    position: relative;
    display: block;
    min-height: 24vw;
    margin-top: 9.6vw;
    overflow: hidden;
    border-radius: 2vw;
    background: rgba(255, 255, 255, 0.92);
    box-shadow: 0 3.2vw 6.4vw rgba(35, 24, 21, 0.1);
    color: #231815;
    text-decoration: none;
  }

  .sp-menu__cta > span:first-child {
    display: block;
    padding: 5.6vw 13.6vw 5.6vw 5.33vw;
    font-size: 4vw;
    font-weight: 700;
    line-height: 1.45;
    letter-spacing: 0.03em;
  }

  .sp-menu__cta strong {
    color: #eb5f20;
  }

  .sp-menu__cta-arrow {
    position: absolute;
    right: 5.33vw;
    bottom: 5.6vw;
    width: 8vw;
    height: 4.8vw;
    color: #eb5f20;
  }

  .sp-menu__cta-arrow::before,
  .sp-menu__cta-arrow::after {
    position: absolute;
    content: "";
  }

  .sp-menu__cta-arrow::before {
    top: 50%;
    left: 0;
    width: 100%;
    height: 0.4vw;
    background: currentColor;
    transform: translateY(-50%);
  }

  .sp-menu__cta-arrow::after {
    top: 50%;
    right: 0;
    width: 2.4vw;
    height: 2.4vw;
    border-top: 0.4vw solid currentColor;
    border-right: 0.4vw solid currentColor;
    transform: translateY(-50%) rotate(45deg);
  }

  .hero-lead {
    left: 5.33%;
    top: 8.25%;
    width: 90%;
    font-size: 2.72vw;
    line-height: 1.78;
    letter-spacing: 0.02em;
  }

  .hero-person {
    left: 26%;
    top: 35.2%;
    bottom: auto;
    width: 105%;
    max-width: none;
    transform: none;
  }

  .hero-title {
    font-size: 12.8vw;
    line-height: 1;
  }

  .hero-title__part--world {
    left: 5.33%;
    top: 20.6%;
  }

  .hero-title__part--change {
    left: 5.33%;
    top: 28.5%;
  }

  .hero-title__part--one {
    left: 5.33%;
    top: 36.35%;
  }

  .hero-title__part--trigger {
    left: 5.33%;
    top: 44.8%;
    width: 50.8%;
    height: 7.28%;
  }

  .hero-title__part--from {
    left: 5.33%;
    top: 52.6%;
  }

  .hero-glasses {
    left: 5.33%;
    top: 61.6%;
    width: 37%;
  }

  .hero-signature {
    left: 5.33%;
    top: 76%;
    font-size: 3.2vw;
    line-height: 1.35;
  }

  .hero-cta {
    left: 4%;
    top: 83.05%;
    width: 92%;
    height: 7.35%;
    border-radius: 5px;
    transform: none;
  }

  .hero-cta::before {
    inset: 0;
    width: 94%;
    height: 100%;
    border-radius: 5px;
    box-shadow: 0 6px 8px rgba(35, 24, 21, 0.12);
    transform: none;
  }

  .hero-cta span {
    left: 10%;
    top: 36%;
    z-index: 1;
    width: 70%;
    font-size: 3.33vw;
    line-height: 1.2;
    text-align: center;
    transform: none;
    white-space: normal;
  }

  .hero-cta img {
    left: auto;
    right: 2.5%;
    top: 30%;
    z-index: 1;
    width: 19%;
    height: auto;
    transform: translateY(-50%) rotate(-5deg);
  }

  /* .sp-concept {
    min-height: 1323px;
    background-position: center center;
  } */

  .concept {
    min-height: 196.4vw;
    background-attachment: fixed;
  }

  .concept-heading {
    left: 7.2%;
    top: 10.5%;
  }

  .concept-heading p {
    margin-bottom: 4.2vw;
    font-size: 3.2vw;
  }

  .concept-heading h2 {
    font-size: 13.6vw;
    line-height: 0.9;
  }

  .concept-copy {
    left: 7.2%;
    top: 30%;
    width: 83%;
    font-size: 3.35vw;
    line-height: 1.85;
  }

  .concept-copy p {
    margin-bottom: 1.35em;
  }

  .sp-workcase {
    aspect-ratio: 750 / 9408;
    background: #eb5f20;
  }

  .sp-work {
    min-height: auto;
    overflow: hidden !important;
  }

  .work-o-stream span {
    width: 48vw;
    border-width: 9vw;
  }

  .work-o-stream span:nth-child(1) {
    left: -18vw;
    bottom: -80vw;
  }

  .work-o-stream span:nth-child(2) {
    right: -22vw;
    bottom: -155vw;
    width: 62vw;
  }

  .work-o-stream span:nth-child(3) {
    left: 38vw;
    bottom: -235vw;
    width: 44vw;
  }

  .work-o-stream--case span:nth-child(1) {
    left: -22vw;
    top: 42vw;
    bottom: auto;
  }

  .work-o-stream--case span:nth-child(2) {
    right: -24vw;
    top: 86vw;
    bottom: auto;
  }

  .work-o-stream--case span:nth-child(3) {
    left: 42vw;
    top: 132vw;
    bottom: auto;
  }

  .work-marquee {
    bottom: 4vw;
    width: 100vw;
  }

  .work-marquee span {
    font-size: 10.5vw;
  }

  .work-layout {
    display: block;
    width: 100%;
    padding: 0 5.33vw 17vw;
  }

  .work-sticky {
    top: 0;
    /* z-index: 4; */
    position: relative;
    display: grid;
    grid-template-columns: 1fr 60vw;
    align-items: start;
    min-height: 44vw;
    padding: 0;
    /* background: rgba(235, 95, 32, 0.94); */
  }

  .section-kicker {
    grid-column: 1;
    margin: 0 0 2.4vw;
    font-size: 3.2vw;
    transform: translateY(16vw);
  }

  .work-sticky h2 {
    grid-column: 1;
    font-size: 13.5vw;
  }

  .work-portrait {
    grid-column: 2;
    grid-row: 1 / span 2;
    width: 68vw;
    margin: 0;
    justify-self: end;
  }

  .work-intro {
    padding-top: 2vw;
  }

  .work-intro__eyebrow {
    padding: 4.4vw 0;
    font-size: 4vw;
    line-height: 1.5;
  }

  .work-intro__lead {
    margin: 8vw 0 8vw;
    font-size: 6.1vw;
    line-height: 1.55;
  }

  .work-card-list {
    gap: 5.33vw;
  }

  .work-card {
    padding: 7.2vw 6.4vw 8vw;
  }

  .work-card__num {
    margin-bottom: 3.2vw;
    font-size: 3.2vw;
  }

  .work-card h3 {
    margin-bottom: 5.6vw;
    font-size: 6vw;
    line-height: 1.45;
  }

  .work-card__lead {
    font-size: 3.75vw;
    line-height: 1.75;
  }

  .work-logo-block {
    width: 100%;
    margin: 5.6vw 0 5vw;
  }

  .work-card ul {
    margin-top: 6vw;
    padding-top: 5.6vw;
  }

  .work-card li {
    margin-bottom: 2.6vw;
    font-size: 3.65vw;
    line-height: 1.55;
  }

  .work-reasons {
    margin-top: 10vw;
  }

  .work-reasons__kicker {
    margin-bottom: 4vw;
    font-size: 3.6vw;
  }

  .work-reason-grid {
    grid-template-columns: 1fr;
    gap: 3.2vw;
  }

  .work-reason-grid article {
    min-height: auto;
    padding: 5.2vw;
  }

  .work-reason-grid h3 {
    font-size: 4.1vw;
  }

  .work-reason-grid p {
    font-size: 3.25vw;
  }

  .case {
    padding: 19.2vw 0 20vw;
  }

  .case::before {
    clip-path: polygon(0 10%, 100% 2.5%, 100% 100%, 0 100%);
  }

  .case-inner {
    width: 89.33vw;
  }

  .case--sp .case-heading {
    width: 100vw;
    margin: -19.2vw calc(50% - 50vw) 9.2vw;
    padding: 19.2vw 5.33vw 0;
    background: linear-gradient(174deg, #eb5f20 0 39%, #ff8b23 39% 100%);
  }

  .case-heading h2 {
    margin-bottom: 4.8vw;
    font-size: 13.6vw;
    text-align: left;
  }

  .case-heading__lead {
    font-size: 5.6vw;
    line-height: 1.5;
    text-align: left;
  }

  .case-heading__note {
    width: 100%;
    margin-top: 4.4vw;
    font-size: 3.467vw;
    line-height: 1.5;
    text-align: left;
  }

  .case-list {
    gap: 2.67vw;
  }

  .case-card {
    padding: 8vw 5.33vw 8vw;
  }

  .case-card__summary {
    padding-right: 12vw;
  }

  .case-card__title {
    font-size: 4.27vw;
    line-height: 1.5;
  }

  .case-card__title span {
    display: block;
  }

  .case-card__subtitle {
    margin-top: 0;
    font-size: 4.27vw;
    line-height: 1.5;
  }

  .case-card__lead {
    margin-top: 7.2vw;
    font-size: 3.47vw;
    line-height: 1.55;
  }

  .case-toggle {
    top: 4vw;
    width: 6.67vw;
    height: 6.67vw;
  }

  .case-toggle::before,
  .case-toggle::after {
    width: 2.67vw;
    height: 0.55vw;
  }

  .case-table-wrap {
    margin: 8vw -2.67vw 0;
  }

  .case-table {
    font-size: 3.42vw;
    line-height: 1.55;
  }

  .case-table__stage {
    width: 26.5%;
  }

  .case-table th {
    padding: 3vw 2.67vw;
    font-size: 3.2vw;
    line-height: 1.3;
  }

  .case-table td {
    padding: 4.6vw 2.67vw;
  }

  .case-table td:first-child {
    padding-right: 2.67vw;
    padding-left: 2.67vw;
    font-size: 3.2vw;
  }

  .case-results {
    padding-left: 1.25em;
  }

  .case-bullet-list,
  .case-bullet-list ul {
    padding-left: 1.05em;
  }

  .case .work-reasons {
    margin-top: 13.33vw;
  }

  .case .work-reasons__kicker {
    margin-bottom: 6.8vw;
    font-size: 4.27vw;
  }

  .case .work-reason-grid {
    grid-template-columns: 1fr;
    gap: 4.8vw;
  }

  .case .work-reason-grid article {
    min-height: auto;
    padding: 7vw 6.2vw;
  }

  .case .work-reason__num {
    margin-bottom: 4.4vw;
    font-size: 3.2vw;
  }

  .case .work-reason-grid h3 {
    margin-bottom: 3.2vw;
    font-size: 5.2vw;
  }

  .case .work-reason-grid h3 span {
    font-size: 3.2vw;
  }

  .case .work-reason-grid p:not(.work-reason__num) {
    font-size: 3.2vw;
  }

  .sp-approach {
    padding: 19vw 5.33vw 16vw;
    background: #f4ece5;
  }

  .approach-inner {
    width: 100%;
  }

  .approach-heading {
    margin-bottom: 9.33vw;
  }

  .approach-heading__kicker {
    margin-bottom: 4vw;
    font-size: 3.2vw;
  }

  .approach-heading h2 {
    margin-bottom: 7.2vw;
    font-size: 12.6vw;
    line-height: 1;
  }

  .approach-heading__copy {
    font-size: 3.65vw;
    line-height: 1.85;
    text-align: left;
  }

  .approach-heading__copy p {
    margin-bottom: 7vw;
  }

  .approach-stack {
    gap: 8vw;
    padding-bottom: 0;
  }

  .approach-card {
    /* --stack-offset: 0vw; */
    /* top: calc(5.6vw + var(--stack-offset)); */
    position: relative;
    top: 0;
    display: block;
    min-height: auto;
    box-shadow: 0 4vw 7vw rgba(35, 24, 21, 0.08);
  }

  .approach-card:nth-child(2) {
    --stack-offset: 3.2vw;
  }

  .approach-card:nth-child(3) {
    --stack-offset: 6.4vw;
  }

  .approach-card:nth-child(4) {
    --stack-offset: 9.6vw;
  }

  .approach-card__image {
    width: calc(100% - 8vw);
    height: 49.07vw;
    margin: 0 0 0 auto;
  }

  .approach-card--grow .approach-card__image {
    height: 49.07vw;
  }

  .approach-card__body {
    padding: 6.4vw 9.33vw 8vw;
  }

  .approach-card__body::after {
    left: 25vw;
    top: 5.8vw;
    width: 58.27vw;
    height: 32.93vw;
  }

  .approach-card__num {
    margin-bottom: 3.2vw;
    font-size: 3.2vw;
  }

  .approach-card h3 {
    margin-bottom: 3.2vw;
    font-size: 8.1vw;
    line-height: 1.2;
  }

  .approach-card__label {
    margin-bottom: 5.2vw;
    font-size: 4.8vw;
    line-height: 1.45;
  }

  .approach-card--grow .approach-card__label {
    margin-bottom: 4.8vw;
  }

  .approach-card__text {
    width: auto;
    font-size: 3.55vw;
    line-height: 1.65;
  }

  .approach-card__note {
    width: auto;
    margin-top: 4.4vw;
    font-size: 2.7vw;
    line-height: 1.6;
  }

  .sp-journal {
    display: flex;
    padding: 13.8vw 5.33vw 13.2vw;
    flex-direction: column;
    background: #fff;
  }

  .journal-heading p {
    font-size: 3.2vw;
    line-height: 1.45;
    letter-spacing: 0.04em;
  }

  .journal-heading h2 {
    margin-top: 3.1vw;
    font-size: 13.35vw;
    line-height: 0.98;
    letter-spacing: 0.015em;
  }

  .journal-list {
    display: grid;
    grid-template-columns: 1fr;
    gap: 12vw;
    margin-top: 9.2vw;
  }

  .journal-card__thumb {
    aspect-ratio: 670 / 448;
  }

  .journal-card__date {
    margin-top: 3.9vw;
    font-size: 3.45vw;
    line-height: 1.5;
    letter-spacing: 0.08em;
  }

  .journal-card h3 {
    margin-top: 3.8vw;
    font-size: 3.75vw;
    line-height: 1.62;
    letter-spacing: 0.03em;
  }

  .journal-more {
    gap: 4.2vw;
    margin-top: 17vw;
    font-size: 3.45vw;
    letter-spacing: 0.02em;
  }

  .journal-more__circle {
    width: 15.8vw;
    height: 15.8vw;
    min-width: 0;
    min-height: 0;
    border-width: 0.27vw;
  }

  .journal-more__circle::before {
    width: 6.3vw;
    height: 0.4vw;
  }

  .journal-more__circle::after {
    width: 3.1vw;
    height: 3.1vw;
    border-top-width: 0.4vw;
    border-right-width: 0.4vw;
    transform: translate(calc(-50% + 1.2vw), -50%) rotate(45deg);
  }

  .sp-company {
    min-height: 276.13vw;
    padding: 13.6vw 5.33vw 19vw;
    background: #f4f4f4;
  }

  .sp-company .company-heading {
    text-align: center;
  }

  .company-heading p {
    font-size: 3.2vw;
    line-height: 1.45;
    letter-spacing: 0.04em;
  }

  .company-heading h2 {
    margin-top: 3.6vw;
    font-size: 13.6vw;
    line-height: 0.98;
    letter-spacing: 0.02em;
  }

  .sp-company .company-portrait {
    width: 31.47vw;
    margin: 5.8vw auto 0;
  }

  .sp-company .company-table {
    width: 100%;
    margin-top: 10.3vw;
  }

  .company-row {
    grid-template-columns: 20.5vw minmax(0, 1fr);
    gap: 1.8vw;
    padding: 5.6vw 0 4.3vw;
    border-bottom-width: 0.27vw;
  }

  .company-row:first-child {
    padding-top: 0;
    padding-bottom: 3.6vw;
  }

  .company-row dt,
  .company-row dd {
    font-size: 3.35vw;
    line-height: 1.62;
    letter-spacing: 0.04em;
  }

  .company-row dt {
    font-size: 3.6vw;
    line-height: 1.58;
  }

  .sp-company .company-row:nth-child(2) {
    padding-top: 6.7vw;
    padding-bottom: 5.3vw;
  }

  .sp-company .company-row dd {
    letter-spacing: 0.03em;
  }

  .sp-company .company-row--business ul:last-of-type li:first-child {
    font-size: 3.25vw;
    letter-spacing: 0.01em;
    white-space: nowrap;
  }

  .company-row--business {
    padding-bottom: 6.3vw;
  }

  .company-row li {
    padding-left: 1.08em;
  }

  .company-lstep {
    width: 29.87vw;
    height: 13.2vw;
    margin: 3.6vw 0 4.8vw 3.6vw;
    border-radius: 0.8vw;
  }

  .company--pc .company-lstep {
    position: static;
  }

  .company-lstep img {
    width: 82%;
  }

  .sp-who {
    background: #fff;
    overflow: hidden;
  }

  .sp-who .who-intro {
    padding: 12.2vw 5.33vw 0;
    background: #fff;
  }

  .sp-who .who-hero {
    position: relative;
    height: 46vw;
  }

  .sp-who .who-title {
    position: absolute;
    left: 15.7vw;
    top: 0;
    font-size: 14.8vw;
    transform: rotate(-7deg);
  }

  .sp-who .who-hello {
    position: absolute;
    left: 29.4vw;
    top: 13.8vw;
    width: 18.8vw;
    height: 18.8vw;
    margin: 0;
    background: var(--who-cream);
  }

  .sp-who .who-kicker {
    position: absolute;
    left: 0;
    top: 35.2vw;
    font-size: 3.1vw;
    font-weight: 900;
    line-height: 1.4;
  }

  .sp-who .who-name {
    position: absolute;
    left: 0;
    top: 43.6vw;
    display: flex;
    align-items: flex-end;
    gap: 1.8vw;
  }

  .sp-who .who-name span {
    font-size: 3.4vw;
  }

  .sp-who .who-name strong {
    font-size: 8.9vw;
    line-height: 0.86;
  }

  .sp-who .who-name em {
    font-size: 6.2vw;
    transform: rotate(-17deg);
  }

  .sp-who .who-swoosh {
    left: 31.6vw;
    top: 55.8vw;
    width: 28vw;
    height: 7.3vw;
    border-bottom: 0.9vw solid rgba(224, 184, 154, 0.34);
    border-left: 0.5vw solid rgba(224, 184, 154, 0.34);
    transform: rotate(-18deg) skewX(-26deg);
  }

  .sp-who .who-story {
    margin-top: 23.2vw;
  }

  .sp-who .who-story h3 {
    margin-bottom: 8vw;
    font-size: 6vw;
    line-height: 1.55;
  }

  .sp-who .who-story p {
    font-size: 2.95vw;
    line-height: 1.84;
    letter-spacing: 0.04em;
  }

  .sp-who .who-story p + p {
    margin-top: 4.5vw;
  }

  .sp-who .who-sp-photos {
    position: relative;
    height: 91vw;
    margin-top: 8vw;
  }

  .sp-who .who-profile {
    position: absolute;
    right: 0;
    top: 0;
    width: 40.5vw;
  }

  .sp-who .who-profile figcaption {
    position: absolute;
    right: calc(100% + 4vw);
    bottom: 18.5vw;
    width: 26vw;
    text-align: left;
  }

  .sp-who .who-profile figcaption span {
    font-size: 2vw;
    line-height: 1.5;
  }

  .sp-who .who-profile figcaption strong {
    margin-top: 1vw;
    font-size: 4.2vw;
    line-height: 1.32;
  }

  .sp-who .who-profile figcaption small {
    margin-top: 0.6vw;
    font-size: 2vw;
  }

  .sp-who .who-photo--laptop {
    left: 0;
    bottom: 8vw;
    width: 28vw;
    height: 19vw;
  }

  .sp-who .who-photo--whiteboard {
    right: 11.4vw;
    bottom: 0;
    width: 24vw;
    height: 18vw;
  }

  .sp-who .who-career {
    margin-top: 0;
    padding: 0 5.33vw 9vw;
    background: var(--who-cream);
  }

  .sp-who .who-career::before {
    position: absolute;
    right: 0;
    bottom: 100%;
    left: 0;
    height: 18vw;
    background: var(--who-cream);
    clip-path: polygon(0 100%, 100% 0, 100% 100%);
    content: "";
  }

  .sp-who .who-career__label {
    position: absolute;
    left: 5.33vw;
    top: -10.4vw;
    z-index: 2;
    width: 26.5vw;
    height: 10.4vw;
    font-size: 3.45vw;
  }

  .sp-who .who-career__inner {
    position: relative;
    min-height: 242vw;
  }

  .sp-who .who-career-block {
    position: absolute;
  }

  .sp-who .who-career-block h3 {
    font-size: 9.8vw;
    line-height: 1.05;
    letter-spacing: 0.04em;
  }

  .sp-who .who-career-block ul,
  .sp-who .who-career-block p {
    margin-top: 3vw;
    font-size: 2.65vw;
    font-weight: 800;
    line-height: 1.65;
    letter-spacing: 0.03em;
  }

  .sp-who .who-career-block--company {
    left: 0;
    top: 17vw;
    width: 52vw;
  }

  .sp-who .who-career-block--brand {
    left: 0;
    top: 83vw;
    width: 57vw;
  }

  .sp-who .who-career-block--brand img {
    position: absolute;
    right: -17vw;
    top: 10vw;
    width: 22vw;
    border-radius: 50%;
  }

  .sp-who .who-career-block--people {
    right: 0;
    top: 14vw;
  }

  .sp-who .who-career-block--people h3 {
    font-size: 10.3vw;
    writing-mode: vertical-rl;
  }

  .sp-who .who-career-block--people p {
    position: absolute;
    right: 12vw;
    top: 62vw;
    margin: 0;
    white-space: nowrap;
    writing-mode: vertical-rl;
  }

  .sp-who .who-career-block--challenge {
    left: 0;
    top: 142vw;
    width: 48vw;
  }

  .sp-who .who-career-arrow {
    position: absolute;
    left: 48vw;
    top: 159vw;
    color: var(--who-orange);
    font-size: 15vw;
    font-weight: 900;
    line-height: 0.8;
  }

  .sp-who .who-career-block--result {
    right: 0;
    top: 176vw;
    width: 52vw;
  }

  .sp-who .who-career-block--result h3 {
    font-size: 8.4vw;
  }

  .sp-who .who-current {
    min-height: 245vw;
    background: var(--who-orange);
  }

  .sp-who .who-current__meeting {
    position: absolute;
    right: 6vw;
    top: -16vw;
    width: 31.8vw;
    height: 31.8vw;
    margin: 0;
    overflow: hidden;
    border-radius: 50%;
  }

  .sp-who .who-award {
    position: absolute;
    left: 6vw;
    top: 8vw;
  }

  .sp-who .who-award h3 {
    font-size: 9.9vw;
    line-height: 1.06;
    writing-mode: vertical-rl;
  }

  .sp-who .who-award p {
    position: absolute;
    left: -4.8vw;
    top: 1vw;
    width: 22vw;
    margin: 0;
    font-size: 2.3vw;
    font-weight: 800;
    line-height: 1.55;
    letter-spacing: 0.04em;
    writing-mode: vertical-rl;
  }

  .sp-who .who-current__logo {
    width: 28vw;
    height: 12.8vw;
    margin-top: 5vw;
  }

  .sp-who .who-current-main {
    position: absolute;
    right: 5.33vw;
    top: 42vw;
    width: 43vw;
  }

  .sp-who .who-current-main h3 {
    font-size: 9.4vw;
    line-height: 1.06;
  }

  .sp-who .who-current-main h3 span {
    display: block;
    margin-top: 1.8vw;
    font-size: 0.32em;
    white-space: nowrap;
  }

  .sp-who .who-current-main ul {
    margin-top: 4vw;
    font-size: 2.6vw;
    font-weight: 800;
    line-height: 1.65;
  }

  .sp-who .who-ai {
    position: absolute;
    left: 24vw;
    top: 111vw;
  }

  .sp-who .who-ai h3 {
    font-size: 14vw;
    line-height: 0.9;
  }

  .sp-who .who-ai p {
    position: absolute;
    left: 13vw;
    top: 0;
    margin: 0;
    font-size: 2.2vw;
    font-weight: 800;
    line-height: 1.55;
    writing-mode: vertical-rl;
  }

  .sp-who .who-local {
    position: absolute;
    left: 5.33vw;
    right: 5.33vw;
    bottom: 8vw;
  }

  .sp-who .who-local h3 {
    font-size: 11.2vw;
    line-height: 1;
  }

  .sp-who .who-local p {
    margin: 4vw 0 0;
    font-size: 4.1vw;
    font-weight: 900;
    line-height: 1.45;
  }

  .sp-who .who-local ul {
    width: 48vw;
    margin-top: 5vw;
    font-size: 2.45vw;
    font-weight: 800;
    line-height: 1.65;
  }

  .sp-who .who-map {
    position: absolute;
    right: 4vw;
    top: 21vw;
    width: 22vw;
    height: 20vw;
    font-size: 1.8vw;
    transform: rotate(-13deg);
  }

  .sp-who .who-local img {
    position: absolute;
    right: 0;
    bottom: 0;
    width: 39vw;
    height: 28vw;
    object-fit: cover;
    border-radius: 1vw;
  }

  .sp-contact {
    aspect-ratio: 750 / 1840;
    background: #ece6e1;
  }

  .sp-footer {
    aspect-ratio: 750 / 993;
    background: #231815;
  }

  .contact-field {
    padding: 0 5.07%;
    border-radius: 5px;
    font-size: 4vw;
  }

  .contact-form--sp .contact-field--name {
    left: 5.33%;
    top: 52.88%;
    width: 89.33%;
    height: 5.43%;
  }

  .contact-form--sp .contact-field--email {
    left: 5.33%;
    top: 64.73%;
    width: 89.33%;
    height: 5.43%;
  }

  .contact-form--sp .contact-field--url {
    left: 5.33%;
    top: 76.68%;
    width: 89.33%;
    height: 5.43%;
  }

  .contact-form--sp .contact-submit {
    left: 19.2%;
    top: 86.96%;
    width: 61.6%;
    height: 5.49%;
  }
}

/* WHO section: node-specific Figma alignment reset. */
.pc-who {
  width: 1280px;
  max-width: 100vw;
  overflow: hidden;
  background: #fff;
}

.pc-who .who-intro,
.pc-who .who-career,
.pc-who .who-current {
  position: relative;
  width: 1280px;
  max-width: 100%;
}

.pc-who .who-intro {
  height: 1374px;
  min-height: 0;
  background: #fff;
}

.pc-who .who-career {
  height: 941px;
  min-height: 0;
  margin-top: -20px;
  background: #f4ede8;
}

.pc-who .who-career::before {
  top: -1px;
  right: auto;
  bottom: auto;
  left: 50%;
  width: 100vw;
  height: 202px;
  background: #fff;
  clip-path: polygon(0 0, 100% 0, 0 100%);
  transform: translateX(-50%);
}

.pc-who .who-current {
  height: 503px;
  min-height: 0;
  overflow: visible;
  background: #eb5f20;
}

.pc-who .who-hero {
  position: static;
}

.pc-who .who-title {
  left: 54px;
  top: 17px;
  z-index: 3;
  color: #eb5f20;
  font-size: 150px;
  line-height: 0.9;
  letter-spacing: -0.03em;
  transform: rotate(-8deg);
}

.pc-who .who-hello {
  left: 158px;
  top: 155px;
  z-index: 1;
  width: 250px;
  height: 250px;
}

.pc-who .who-hello img {
  object-position: 50% 50%;
}

.pc-who .who-kicker {
  left: 438px;
  top: 231px;
  color: #231815;
  font-size: 34px;
  font-weight: 500;
  line-height: 1.5;
  letter-spacing: 0.06em;
}

.pc-who .who-name {
  left: 0;
  top: 0;
  display: block;
}

.pc-who .who-name span,
.pc-who .who-name strong,
.pc-who .who-name em {
  position: absolute;
  display: block;
  margin: 0;
  letter-spacing: 0.03em;
}

.pc-who .who-name span {
  left: 438px;
  top: 296px;
  color: #eb5f20;
  font-size: 36px;
  font-weight: 500;
  line-height: 1.3;
}

.pc-who .who-name strong {
  left: 551px;
  top: 296px;
  color: #eb5f20;
  font-size: 100px;
  font-weight: 700;
  line-height: 0.82;
  letter-spacing: 0.03em;
  white-space: nowrap;
}

.pc-who .who-name__to {
  left: 953px;
  top: 294px;
  color: #231815;
  font-size: 46px;
  font-weight: 500;
  line-height: 1.3;
  transform: none;
  white-space: nowrap;
}

.pc-who .who-name__ha {
  left: 989px;
  top: 334px;
  color: #231815;
  font-size: 46px;
  font-weight: 500;
  line-height: 1.3;
  transform: none;
  white-space: nowrap;
}

.pc-who .who-name__q {
  left: 999px;
  top: 286px;
  color: #231815;
  font-family: "sweet-sans-pro", sans-serif;
  font-size: 120px;
  font-weight: 700;
  line-height: 0.9;
  letter-spacing: -0.03em;
  transform: rotate(10deg);
  white-space: nowrap;
}

.pc-who .who-swoosh {
  left: 432px;
  top: 350px;
  width: 317px;
  height: auto;
  border: 0;
  transform: none;
}

.pc-who .who-story {
  left: 88px;
  top: 495px;
  width: 670px;
}

.pc-who .who-story h3 {
  margin: 0 0 41px;
  font-size: 38px;
  font-weight: 500;
  line-height: 1.5;
  letter-spacing: 0.06em;
}

.pc-who .who-story p {
  font-size: 16px;
  font-weight: 400;
  line-height: 1.8;
  letter-spacing: 0.06em;
}

.pc-who .who-story p + p {
  margin-top: 28px;
}

.pc-who .who-story small {
  display: inline;
  font-size: 12px;
  letter-spacing: 0.06em;
}

.pc-who .who-glasses {
  position: absolute;
  left: 439px;
  top: 1120px;
  z-index: 2;
  width: 235px;
  height: auto;
}

.pc-who .who-profile {
  left: 760px;
  top: 596px;
  width: 358px;
}

.pc-who .who-profile > img {
  width: 358px;
  height: 477px;
  object-fit: cover;
  object-position: 50% 50%;
}

.pc-who .who-profile figcaption {
  position: absolute;
  left: 0;
  top: 507px;
  width: 358px;
  margin: 0;
  text-align: center;
}

.pc-who .who-profile figcaption span {
  font-size: 14px;
  font-weight: 500;
  line-height: 1.5;
  letter-spacing: 0;
}

.pc-who .who-profile figcaption strong {
  margin-top: 2px;
  font-size: 24px;
  font-weight: 500;
  line-height: 1.3;
  letter-spacing: 0.2em;
}

.pc-who .who-profile figcaption small {
  margin-top: 1px;
  font-family: "Sofia Pro", "Helvetica Neue", sans-serif;
  font-size: 13px;
  font-weight: 400;
  line-height: 1.3;
  letter-spacing: 0;
}

.pc-who .who-photo {
  object-fit: cover;
  object-position: center;
}

.pc-who .who-photo--laptop {
  left: 992px;
  top: 1237px;
  width: 200px;
  height: 200px;
}

.pc-who .who-photo--whiteboard {
  left: 760px;
  top: 1387px;
  z-index: 3;
  width: 200px;
  height: 200px;
  box-shadow: 0 4px 4px rgba(0, 0, 0, 0.25);
  transform: rotate(-1.05deg);
}

.pc-who .who-career__label {
  left: 88px;
  top: 261px;
  z-index: 3;
  width: 247px;
  height: 82px;
  font-size: 28px;
  font-weight: 500;
  line-height: 1.3;
  letter-spacing: -0.03em;
}

.pc-who .who-career__inner {
  height: 941px;
}

.pc-who .who-career-block h3 {
  font-weight: 700;
  letter-spacing: 0;
}

.pc-who .who-career-block ul,
.pc-who .who-career-block p,
.pc-who .who-current ul,
.pc-who .who-current p {
  color: inherit;
  font-size: 14px;
  font-weight: 500;
  line-height: 1.5;
  letter-spacing: 0.06em;
}

.pc-who .who-career-block li,
.pc-who .who-current li {
  padding-left: 18px;
}

.pc-who .who-career-block li::before,
.pc-who .who-current li::before {
  top: 0.45em;
  width: 8px;
  height: 8px;
  background: currentColor;
  content: "";
}

.pc-who .who-career-block--company {
  left: 88px;
  top: 403px;
  width: 492px;
}

.pc-who .who-career-block--company h3 {
  font-size: 72px;
  line-height: 1.15;
}

.pc-who .who-career-block--company h3 span {
  position: relative;
  left: -25px;
  display: inline-block;
  color: #231815;
  font-size: 44px;
  font-weight: 500;
  letter-spacing: 0.06em;
}

.pc-who .who-career-block--company ul {
  margin-top: 26px;
  width: 505px;
}

.pc-who .who-career-block--brand {
  left: 88px;
  top: 707px;
  width: 555px;
}

.pc-who .who-career-block--brand h3 {
  font-size: 70px;
  line-height: 1.1;
}

.pc-who .who-career-block--brand ul {
  margin-top: 18px;
}

.pc-who .who-career-block--brand img {
  left: 288px;
  right: auto;
  top: -110px;
  width: 150px;
  height: 150px;
  border-radius: 50%;
  object-fit: cover;
}

.pc-who .who-career-block--people {
  left: 612px;
  top: 403px;
}

.pc-who .who-career-block--people h3 {
  font-size: 84px;
  font-weight: 700;
  line-height: 88px;
  letter-spacing: -0.03em;
  writing-mode: vertical-rl;
}

.pc-who .who-career-block--people p {
  left: -55px;
  top: 200px;
  margin: 0;
  white-space: nowrap;
  writing-mode: vertical-rl;
}

.pc-who .who-career-block--challenge {
  left: 856px;
  top: 403px;
  width: 340px;
}

.pc-who .who-career-block--challenge h3 {
  font-size: 110px;
  line-height: 0.96;
  letter-spacing: -0.03em;
}

.pc-who .who-career-block--challenge ul {
  position: absolute;
  left: 130px;
  top: 4px;
  width: 260px;
  margin: 0;
}

.pc-who .who-career-arrow {
  right: auto;
  left: 1020px;
  top: 535px;
  width: 80px;
  height: 101px;
}

.pc-who .who-career-arrow img {
  width: 100%;
  height: auto;
}

.pc-who .who-career-block--result {
  right: auto;
  left: 746px;
  top: 697px;
  bottom: auto;
  width: 460px;
}

.pc-who .who-career-block--result h3 {
  font-size: 72px;
  line-height: 1.1;
}

.pc-who .who-career-block--result ul {
  position: absolute;
  left: 0;
  top: 88px;
  width: 270px;
  margin: 0;
}

.pc-who .who-career-block--result h3 br {
  display: none;
}

.pc-who .who-career-block--result h3::after {
  content: "成果";
  position: absolute;
  left: 288px;
  top: 81px;
  font-size: 80px;
  line-height: 1.1;
}

.pc-who .who-current h3 {
  color: #f4ece5;
  font-weight: 700;
  letter-spacing: 0;
}

.pc-who .who-current ul,
.pc-who .who-current p {
  color: #f4ece5;
}

.pc-who .who-current__meeting {
  right: auto;
  left: 508px;
  top: -79px;
  width: 200px;
  height: 200px;
}

.pc-who .who-award {
  left: 88px;
  top: 50px;
  width: 210px;
}

.pc-who .who-award h3 {
  font-size: 70px;
  line-height: 74px;
  writing-mode: vertical-rl;
}

.pc-who .who-award p {
  left: 0;
  top: 0;
  font-size: 14px;
  font-weight: 500;
  line-height: 1.15;
  letter-spacing: 0.06em;
  writing-mode: vertical-rl;
}

.pc-who .who-current__logo {
  position: absolute;
  left: 52px;
  top: 313px;
  width: 155px;
  height: 70px;
  margin: 0;
  border-radius: 3px;
}

.pc-who .who-current__logo img {
  width: 125px;
}

.pc-who .who-current-main {
  left: 335px;
  top: 50px;
  width: 596px;
}

.pc-who .who-current-main h3 {
  font-size: 80px;
  line-height: 1.25;
  white-space: nowrap;
}

.pc-who .who-current-main h3 span {
  font-size: 24px;
  font-weight: 700;
}

.pc-who .who-current-main ul {
  display: block;
  margin-top: 16px;
  width: 486px;
}

.pc-who .who-ai {
  right: auto;
  left: 1108px;
  top: 149px;
  text-align: left;
}

.pc-who .who-ai h3 {
  font-size: 90px;
  line-height: 0.95;
}

.pc-who .who-ai p {
  position: absolute;
  left: 24px;
  top: 86px;
  margin: 0;
  font-size: 14px;
  font-weight: 500;
  line-height: 1.15;
  letter-spacing: 0.06em;
  writing-mode: vertical-rl;
}

.pc-who .who-local {
  left: 707px;
  bottom: auto;
  top: 225px;
  width: 485px;
}

.pc-who .who-local h3 {
  font-size: 90px;
  line-height: 1.1;
}

.pc-who .who-local p {
  margin: 0 0 0 7px;
  font-size: 25px;
  font-weight: 700;
  line-height: 1.3;
}

.pc-who .who-local ul {
  margin: 20px 0 0 7px;
  width: 320px;
}

.pc-who .who-map {
  position: absolute;
  left: 322px;
  top: -12px;
  width: 132px;
  height: auto;
  background: none;
  clip-path: none;
  transform: rotate(-12deg);
}

.pc-who .who-local__seminar {
  position: absolute;
  left: -378px;
  top: -4px;
  width: 293px;
  height: 195px;
  object-fit: cover;
  border-radius: 0;
}

@media (max-width: 767px) {
  .sp-who {
    width: 100vw;
    overflow: hidden;
    background: #fff;
  }

  .sp-who .who-intro,
  .sp-who .who-career,
  .sp-who .who-current {
    position: relative;
    width: 100vw;
  }

  .sp-who .who-intro {
    height: 465.33vw;
    padding: 0;
    background: #fff;
  }

  .sp-who .who-career {
    height: 219.87vw;
    min-height: 0;
    margin: -3vw 0 0;
    padding: 0;
    background: #f4ede8;
  }

  .sp-who .who-career::before {
    top: -1px;
    right: auto;
    bottom: auto;
    left: 50%;
    width: 100vw;
    height: 26.93vw;
    background: #fff;
    clip-path: polygon(0 0, 100% 0, 0 100%);
    transform: translateX(-50%);
  }

  .sp-who .who-current {
    height: 190.4vw;
    min-height: 0;
    overflow: visible;
    background: #eb5f20;
  }

  .sp-who .who-hero {
    position: static;
    height: auto;
  }

  .sp-who .who-title {
    left: 19.87vw;
    top: 5.07vw;
    z-index: 3;
    font-size: 20vw;
    line-height: 0.9;
    letter-spacing: -0.03em;
    transform: rotate(-8deg);
  }

  .sp-who .who-hello {
    left: 33.73vw;
    top: 23.41vw;
    z-index: 1;
    width: 33.33vw;
    height: 33.33vw;
  }

  .sp-who .who-kicker {
    left: 5.33vw;
    top: 60.8vw;
    font-size: 4.53vw;
    font-weight: 500;
    line-height: 1.5;
    letter-spacing: 0.06em;
  }

  .sp-who .who-name {
    left: 0;
    top: 0;
    display: block;
  }

  .sp-who .who-name span,
  .sp-who .who-name strong,
  .sp-who .who-name em {
    position: absolute;
    display: block;
    margin: 0;
    letter-spacing: 0.03em;
  }

  .sp-who .who-name span {
    left: 5.33vw;
    top: 69.47vw;
    color: #eb5f20;
    font-size: 4.8vw;
    font-weight: 500;
    line-height: 1.3;
  }

  .sp-who .who-name strong {
    left: 20.4vw;
    top: 69.47vw;
    color: #eb5f20;
    font-size: 13.33vw;
    font-weight: 700;
    line-height: 0.82;
    letter-spacing: 0.03em;
    white-space: nowrap;
  }

  .sp-who .who-name__to {
    left: 74vw;
    top: 69.2vw;
    color: #231815;
    font-size: 6.13vw;
    font-weight: 500;
    line-height: 1.3;
    transform: none;
    white-space: nowrap;
  }

  .sp-who .who-name__ha {
    left: 78.8vw;
    top: 74.53vw;
    color: #231815;
    font-size: 6.13vw;
    font-weight: 500;
    line-height: 1.3;
    transform: none;
    white-space: nowrap;
  }

  .sp-who .who-name__q {
    left: 80.13vw;
    top: 68.13vw;
    color: #231815;
    font-family: "sweet-sans-pro", sans-serif;
    font-size: 16vw;
    font-weight: 700;
    line-height: 0.9;
    letter-spacing: -0.03em;
    transform: rotate(10deg);
    white-space: nowrap;
  }

  .sp-who .who-swoosh {
    left: 36.8vw;
    top: 88vw;
    width: 42.27vw;
    height: auto;
    border: 0;
    transform: none;
  }

  .sp-who .who-story {
    position: absolute;
    left: 5.33vw;
    top: 95.2vw;
    width: 89.33vw;
    margin: 0;
  }

  .sp-who .who-story h3 {
    margin: 0 0 4.67vw;
    font-size: 6.13vw;
    font-weight: 500;
    line-height: 1.5;
    letter-spacing: 0.06em;
  }

  .sp-who .who-story p {
    margin: 0;
    font-size: 3.47vw;
    font-weight: 400;
    line-height: 1.8;
    letter-spacing: 0.06em;
  }

  .sp-who .who-story p + p {
    margin-top: 4.53vw;
  }

  .sp-who .who-story small {
    font-size: 2.93vw;
  }

  .sp-who .who-glasses {
    position: absolute;
    top: 208.6vw;
    left: 54vw;
    z-index: -1;
    width: 40.93vw;
    height: auto;
  }

  .sp-who .who-sp-photos {
    position: static;
    height: auto;
    margin: 0;
  }

  .sp-who .who-profile {
    right: auto;
    left: 40vw;
    top: 361.07vw;
    width: 54.67vw;
  }

  .sp-who .who-profile > img {
    width: 54.67vw;
    height: 72.93vw;
    object-fit: cover;
    object-position: 50% 50%;
  }

  .sp-who .who-profile figcaption {
    position: absolute;
    right: auto;
    left: -27.47vw;
    top: 29.33vw;
    bottom: auto;
    width: 25.33vw;
    margin: 0;
    text-align: left;
  }

  .sp-who .who-profile figcaption span {
    font-size: 2.67vw;
    font-weight: 500;
    line-height: 1.5;
    letter-spacing: 0;
  }

  .sp-who .who-profile figcaption strong {
    margin-top: 1.2vw;
    font-size: 4.8vw;
    font-weight: 500;
    line-height: 1.3;
    letter-spacing: 0.2em;
  }

  .sp-who .who-profile figcaption small {
    margin-top: 0.27vw;
    font-family: "Sofia Pro", "Helvetica Neue", sans-serif;
    font-size: 2.4vw;
    font-weight: 400;
    line-height: 1.3;
  }

  .sp-who .who-photo--laptop {
    left: 5.33vw;
    top: 427.33vw;
    bottom: auto;
    width: 30.67vw;
    height: 30.67vw;
  }

  .sp-who .who-photo--whiteboard {
    right: auto;
    left: 52vw;
    top: 443.33vw;
    bottom: auto;
    width: 30.67vw;
    height: 30.67vw;
    box-shadow: 0 0.53vw 0.53vw rgba(0, 0, 0, 0.25);
    transform: rotate(-1.05deg);
  }

  .sp-who .who-career__label {
    left: 5.33vw;
    top: 24.67vw;
    z-index: 3;
    width: 41.73vw;
    height: 13.87vw;
    font-size: 4.8vw;
    font-weight: 500;
    line-height: 1.3;
    letter-spacing: -0.03em;
  }

  .sp-who .who-career__inner {
    height: 219.87vw;
    min-height: 0;
  }

  .sp-who .who-career-block h3 {
    font-weight: 700;
    letter-spacing: 0;
  }

  .sp-who .who-career-block ul,
  .sp-who .who-career-block p,
  .sp-who .who-current ul,
  .sp-who .who-current p {
    color: inherit;
    font-size: 2.67vw;
    font-weight: 500;
    line-height: 1.5;
    letter-spacing: 0.06em;
  }

  .sp-who .who-career-block li,
  .sp-who .who-current li {
    padding-left: 3.2vw;
  }

  .sp-who .who-career-block li::before,
  .sp-who .who-current li::before {
    top: 0.45em;
    width: 1.6vw;
    height: 1.6vw;
    background: currentColor;
    content: "";
  }

  .sp-who .who-career-block--company {
    left: 5.33vw;
    top: 48.4vw;
    width: 70vw;
  }

  .sp-who .who-career-block--company h3 {
    font-size: 12.13vw;
    line-height: 1.15;
  }

  .sp-who .who-career-block--company h3 span {
    position: relative;
    left: -3.33vw;
    display: inline-block;
    color: #231815;
    font-size: 7.33vw;
    font-weight: 500;
    letter-spacing: 0.06em;
  }

  .sp-who .who-career-block--company ul {
    margin-top: 4.27vw;
    width: 62vw;
  }

  .sp-who .who-career-block--brand {
    left: 5.33vw;
    top: 103.47vw;
    width: 63vw;
  }

  .sp-who .who-career-block--brand h3 {
    font-size: 12.27vw;
    line-height: 1.1;
  }

  .sp-who .who-career-block--brand ul {
    margin-top: 4.4vw;
  }

  .sp-who .who-career-block--brand img {
    left: 44.8vw;
    right: auto;
    top: -5.07vw;
    width: 20vw;
    height: 20vw;
    border-radius: 50%;
    object-fit: cover;
  }

  .sp-who .who-career-block--people {
    right: auto;
    left: 81.6vw;
    top: 36.93vw;
  }

  .sp-who .who-career-block--people h3 {
    font-size: 13.07vw;
    font-weight: 700;
    line-height: 11.73vw;
    letter-spacing: -0.03em;
    writing-mode: vertical-rl;
  }

  .sp-who .who-career-block--people p {
    right: auto;
    left: -12.27vw;
    top: 79.6vw;
    margin: 0;
    white-space: nowrap;
    writing-mode: vertical-rl;
  }

  .sp-who .who-career-block--challenge {
    left: 5.47vw;
    top: 151.73vw;
    width: 48vw;
  }

  .sp-who .who-career-block--challenge h3 {
    font-size: 18.13vw;
    line-height: 0.96;
    letter-spacing: -0.03em;
  }

  .sp-who .who-career-block--challenge ul {
    position: absolute;
    left: 40.27vw;
    top: 1.2vw;
    width: 46vw;
    margin: 0;
  }

  .sp-who .who-career-arrow {
    left: 63.87vw;
    top: 164.27vw;
    width: 12.67vw;
    height: auto;
  }

  .sp-who .who-career-arrow img {
    width: 100%;
    height: auto;
  }

  .sp-who .who-career-block--result {
    right: auto;
    left: 5.33vw;
    top: 186.93vw;
    width: 92vw;
  }

  .sp-who .who-career-block--result h3 {
    font-size: 12.27vw;
    line-height: 1.1;
    white-space: nowrap;
  }

  .sp-who .who-career-block--result ul {
    position: absolute;
    left: 0;
    top: 13.73vw;
    width: 40vw;
    margin: 0;
  }

  .sp-who .who-career-block--result h3 br {
    display: none;
  }

  .sp-who .who-current h3 {
    color: #f4ece5;
    font-weight: 700;
    letter-spacing: 0;
  }

  .sp-who .who-current ul,
  .sp-who .who-current p {
    color: #f4ece5;
  }

  .sp-who .who-current__meeting {
    right: auto;
    left: 54.27vw;
    top: -4vw;
    width: 32.53vw;
    height: 32.53vw;
  }

  .sp-who .who-award {
    left: 5.33vw;
    top: 9.33vw;
    width: 36vw;
  }

  .sp-who .who-award h3 {
    font-size: 12.53vw;
    line-height: 13.87vw;
    writing-mode: vertical-rl;
  }

  .sp-who .who-award p {
    left: 0;
    top: 0;
    width: auto;
    font-size: 2.67vw;
    font-weight: 500;
    line-height: 1.15;
    letter-spacing: 0.06em;
    writing-mode: vertical-rl;
  }

  .sp-who .who-current__logo {
    position: absolute;
    left: 9.33vw;
    top: 53.73vw;
    width: 26.4vw;
    height: 11.73vw;
    margin: 0;
    border-radius: 0.4vw;
  }

  .sp-who .who-current__logo img {
    width: 21.33vw;
  }

  .sp-who .who-current-main {
    right: auto;
    left: 46.4vw;
    top: 35.87vw;
    width: 48vw;
  }

  .sp-who .who-current-main h3 {
    font-size: 15.2vw;
    line-height: 1.08;
  }

  .sp-who .who-current-main h3 span {
    display: block;
    margin-top: 1vw;
    font-size: 4.27vw;
    font-weight: 700;
    line-height: 1.3;
    white-space: nowrap;
  }

  .sp-who .who-current-main ul {
    display: block;
    margin-top: 4.8vw;
    width: 46vw;
  }

  .sp-who .who-ai {
    left: 24.93vw;
    top: 84.13vw;
  }

  .sp-who .who-ai h3 {
    font-size: 15.2vw;
    line-height: 0.95;
  }

  .sp-who .who-ai p {
    left: 13.47vw;
    top: 0;
    margin: 0;
    font-size: 2.67vw;
    font-weight: 500;
    line-height: 1.15;
    letter-spacing: 0.06em;
    writing-mode: vertical-rl;
  }

  .sp-who .who-local {
    left: 5.33vw;
    right: auto;
    top: 108.8vw;
    bottom: auto;
    width: 89.33vw;
  }

  .sp-who .who-local h3 {
    font-size: 16vw;
    line-height: 1.06;
  }

  .sp-who .who-local p {
    margin: 0 0 0 0.93vw;
    font-size: 4.53vw;
    font-weight: 700;
    line-height: 1.3;
  }

  .sp-who .who-local ul {
    margin-top: 4.93vw;
    width: 42vw;
  }

  .sp-who .who-map {
    position: absolute;
    left: 65.07vw;
    top: -10.93vw;
    width: 18.93vw;
    height: auto;
    background: none;
    clip-path: none;
    transform: rotate(-12deg);
  }

  .sp-who .who-local__seminar {
    position: absolute;
    left: 42.27vw;
    top: 31.6vw;
    width: 47.2vw;
    height: 31.33vw;
    object-fit: cover;
    border-radius: 0;
  }
}

.pc-who .who-name em.who-name__to {
  left: 953px;
  top: 294px;
  font-size: 46px;
  line-height: 1.3;
  transform: none;
}

.pc-who .who-name em.who-name__ha {
  left: 989px;
  top: 334px;
  font-size: 46px;
  line-height: 1.3;
  transform: none;
}

.pc-who .who-name em.who-name__q {
  left: 999px;
  top: 286px;
  font-size: 120px;
  line-height: 0.9;
  transform: rotate(10deg);
}

.pc-who .who-swoosh {
  height: 66px;
}

.pc-who .who-glasses {
  height: 121px;
}

.pc-who .who-career-arrow img {
  width: 80px;
  height: 101px;
}

.pc-who .who-local .who-map {
  left: 322px;
  top: -12px;
  width: 126px;
  height: 162px;
}

.pc-who .who-local .who-local__seminar {
  left: -378px;
  top: -4px;
  width: 293px;
  height: 195px;
  object-fit: cover;
  border-radius: 0;
}

@media (max-width: 767px) {
  .sp-who .who-name em.who-name__to {
    left: 74vw;
    top: 69.2vw;
    font-size: 6.13vw;
    line-height: 1.3;
    transform: none;
  }

  .sp-who .who-name em.who-name__ha {
    left: 78.8vw;
    top: 74.53vw;
    font-size: 6.13vw;
    line-height: 1.3;
    transform: none;
  }

  .sp-who .who-name em.who-name__q {
    left: 80.13vw;
    top: 68.13vw;
    font-size: 16vw;
    line-height: 0.9;
    transform: rotate(10deg);
  }

  .sp-who .who-swoosh {
    height: 8.77vw;
  }

  .sp-who .who-glasses {
    height: 16.13vw;
  }

  .sp-who .who-career-arrow img {
    width: 12.67vw;
    height: 16vw;
  }

  .sp-who .who-local .who-map {
    left: 65.07vw;
    top: -10.93vw;
    width: 16.8vw;
    height: 21.53vw;
  }

  .sp-who .who-local .who-local__seminar {
    left: 42.27vw;
    top: 31.6vw;
    width: 47.2vw;
    height: 31.33vw;
    object-fit: cover;
    border-radius: 0;
  }
}

/* WHO section composed from the exported Figma parts, not a full-section screenshot. */
.who-heading-art,
.who-words-art,
.who-words-photo {
  position: absolute;
  display: block;
  max-width: none;
  height: auto;
  pointer-events: none;
  user-select: none;
}

.pc-who .who-heading-art {
  left: 42px;
  top: 0;
  z-index: 3;
  width: 1078px;
}

.pc-who .who-glasses {
  top: 890px;
  left: 440px;
  z-index: -1;
  width: 235px;
  height: auto;
}

.pc-who .who-profile > img {
  width: 358px;
  height: 477px;
  object-fit: contain;
}

.pc-who .who-photo--laptop,
.pc-who .who-photo--whiteboard {
  width: 200px;
  height: 200px;
  object-fit: contain;
}

.pc-who .who-words-art--career {
  left: 60px;
  top: 290px;
  z-index: 2;
  width: 1129px;
}

.pc-who .who-words-photo {
  left: 915px;
  top: -79px;
  z-index: 3;
  width: 203px;
}

.pc-who .who-words-art--current {
  left: 88px;
  top: 50px;
  z-index: 2;
  width: 1104px;
}

.pc-who .who-intro {
  z-index: 2;
}

.pc-who .who-career {
  z-index: 1;
}

.pc-who .who-career::before {
  z-index: 0;
}

.pc-who .who-career__label,
.pc-who .who-career__inner {
  position: relative;
  z-index: 1;
}

.pc-who .who-photo--whiteboard {
  box-shadow: none;
}

.pc-who .who-words-photo {
  left: 975px;
  top: -92px;
}

@media (max-width: 767px) {
  .sp-who .who-heading-art {
    left: 5.33vw;
    top: 6vw;
    z-index: 3;
    width: 92.53vw;
  }

  .sp-who .who-profile > img {
    width: 54.67vw;
    height: 72.93vw;
    object-fit: contain;
  }

  .sp-who .who-photo--laptop,
  .sp-who .who-photo--whiteboard {
    width: 30.67vw;
    height: 30.67vw;
    object-fit: contain;
  }

  .sp-who .who-words-art--career {
    left: 1.87vw;
    top: 18vw;
    z-index: 2;
    width: 92.8vw;
  }

  .sp-who .who-words-photo {
    left: 42.4vw;
    top: -4.8vw;
    z-index: 3;
    width: 32.53vw;
  }

  .sp-who .who-words-art--current {
    left: 5.33vw;
    top: 13.33vw;
    z-index: 2;
    width: 90.13vw;
  }

  .sp-who .who-intro {
    z-index: 2;
  }

  .sp-who .who-career {
    z-index: 1;
  }

  .sp-who .who-career::before {
    z-index: 0;
  }

  .sp-who .who-career__label,
  .sp-who .who-career__inner {
    position: relative;
    z-index: 1;
  }

  .sp-who .who-photo--whiteboard {
    box-shadow: none;
  }

  .sp-who .who-words-photo {
    left: 48vw;
    top: -7.6vw;
  }
}

.contact {
  --contact-orange: #f15a1c;
  --contact-bg: #e9e9e9;
  position: relative;
  overflow: hidden;
  background: var(--contact-bg);
  color: #231815;
}

.pc-contact {
  height: 890px;
  aspect-ratio: auto;
  background: linear-gradient(to bottom, var(--contact-bg) 0 890px, #fff 890px 100%);
}

.contact-copy,
.contact-person,
.contact-label,
.contact-field,
.contact-submit,
.contact-message {
  position: absolute;
}

.contact-copy {
  margin: 0;
}

.contact-kicker,
.contact-copy h2,
.contact-copy h3,
.contact-copy p {
  margin: 0;
}

.contact-kicker {
  color: var(--contact-orange);
  font-weight: 500;
  letter-spacing: 0.06em;
}

.contact-copy h2 {
  color: var(--contact-orange);
  font-family: "sweet-sans-pro", sans-serif;
  font-weight: 700;
  line-height: 0.9;
  letter-spacing: 0.05em;
}

.contact-copy h3 {
  font-weight: 700;
  letter-spacing: 0.06em;
}

.contact-copy p:not(.contact-kicker) {
  font-weight: 400;
  letter-spacing: 0.06em;
}

.contact-label {
  margin: 0;
  font-weight: 700;
  letter-spacing: 0.06em;
}

.contact-label span {
  color: var(--contact-orange);
  font-weight: 500;
}

.contact .contact-field {
  border: 0;
  border-radius: 5px;
  appearance: none;
  background: #fff;
  color: #231815;
  font-family: inherit;
  font-weight: 700;
  letter-spacing: 0.08em;
}

.contact .contact-field::placeholder {
  color: #bfb9b6;
  opacity: 1;
}

.contact .contact-submit {
  display: flex;
  align-items: center;
  justify-content: center;
  border: 0;
  border-radius: 999px;
  appearance: none;
  background: var(--contact-orange);
  color: #fff;
  cursor: pointer;
  font-family: inherit;
  font-weight: 700;
  letter-spacing: 0.06em;
}

.contact .contact-submit:disabled {
  cursor: wait;
  opacity: 0.72;
}

.contact-honeypot {
  position: absolute;
  left: -9999px;
  width: 1px;
  height: 1px;
  opacity: 0;
  pointer-events: none;
}

.contact-message {
  margin: 0;
  color: #231815;
  font-weight: 700;
  letter-spacing: 0.05em;
}

.contact-message[data-state="success"] {
  color: #2b6e48;
}

.contact-message[data-state="error"] {
  color: #c43f24;
}

.contact-submit__arrow {
  position: relative;
  display: block;
  flex: 0 0 auto;
}

.contact-submit__arrow::before,
.contact-submit__arrow::after {
  position: absolute;
  content: "";
}

.contact-submit__arrow::before {
  top: 50%;
  right: 0;
  width: 100%;
  height: 2px;
  background: currentColor;
  transform: translateY(-50%);
}

.contact-submit__arrow::after {
  top: 50%;
  right: 0;
  width: 13px;
  height: 13px;
  border-top: 2px solid currentColor;
  border-right: 2px solid currentColor;
  transform: translateY(-50%) rotate(45deg);
}

.pc-contact .contact-copy {
  left: 88px;
  top: 79px;
  width: 410px;
}

.pc-contact .contact-kicker {
  font-size: 16px;
  line-height: 1.5;
}

.pc-contact .contact-copy h2 {
  margin-top: 21px;
  font-size: 76px;
}

.pc-contact .contact-copy h3 {
  margin-top: 46px;
  font-size: 20px;
  line-height: 1.5;
}

.pc-contact .contact-copy p:not(.contact-kicker) {
  margin-top: 25px;
  font-size: 14px;
  line-height: 1.8;
}

.pc-contact .contact-person {
  left: 80px;
  top: 490px;
  width: 390px;
  height: auto;
}

.slice.contact > img.contact-person {
  position: absolute;
  display: block;
  max-width: none;
}

.slice.pc-contact > img.contact-person {
  width: 390px;
  height: auto;
}

.pc-contact .contact-label {
  left: 572px;
  font-size: 16px;
  line-height: 1.5;
}

.pc-contact .contact-label span {
  margin-left: 15px;
}

.pc-contact .contact-label--name {
  top: 251px;
}

.pc-contact .contact-label--email {
  top: 393px;
}

.pc-contact .contact-label--url {
  top: 534px;
}

.pc-contact .contact-field {
  left: 572px;
  width: 620px;
  height: 59px;
  padding: 0 30px;
  font-size: 17px;
}

.pc-contact .contact-field--name {
  top: 296px;
}

.pc-contact .contact-field--email {
  top: 437px;
}

.pc-contact .contact-field--url {
  top: 579px;
}

.pc-contact .contact-submit {
  left: 572px;
  top: 708px;
  width: 356px;
  height: 75px;
  gap: 21px;
  padding: 0 34px 0 42px;
  font-size: 20px;
}

.pc-contact .contact-message {
  left: 572px;
  top: 800px;
  width: 620px;
  font-size: 13px;
  line-height: 1.6;
}

.pc-contact .contact-submit__arrow {
  width: 30px;
  height: 22px;
}

@media (max-width: 767px) {
  .sp-contact {
    height: 245.33vw;
    aspect-ratio: auto;
    background: var(--contact-bg);
  }

  .sp-contact .contact-copy {
    left: 5.33vw;
    top: 18.27vw;
    width: 89.33vw;
  }

  .sp-contact .contact-kicker {
    margin-left: 1.73vw;
    font-size: 3.2vw;
    line-height: 1.5;
  }

  .sp-contact .contact-copy h2 {
    margin-top: 2.13vw;
    font-size: 12.13vw;
    line-height: 0.98;
  }

  .sp-contact .contact-copy h3 {
    margin-top: 7.6vw;
    font-size: 4.53vw;
    line-height: 1.5;
  }

  .sp-contact .contact-copy p:not(.contact-kicker) {
    margin-top: 5.33vw;
    font-size: 3.47vw;
    line-height: 1.9;
  }

  .sp-contact .contact-person {
    left: 61vw;
    top: 82.93vw;
    width: 38.67vw;
    height: 48.8vw;
    object-fit: cover;
  }

  .slice.sp-contact > img.contact-person {
    width: 38.67vw;
    height: 48.8vw;
  }

  .sp-contact .contact-label {
    left: 5.33vw;
    font-size: 3.47vw;
    line-height: 1.5;
  }

  .sp-contact .contact-label span {
    margin-left: 2.4vw;
  }

  .sp-contact .contact-label--name {
    top: 122.8vw;
  }

  .sp-contact .contact-label--email {
    top: 152.27vw;
  }

  .sp-contact .contact-label--url {
    top: 181.33vw;
  }

  .sp-contact .contact-field {
    left: 5.33vw;
    width: 89.33vw;
    height: 13.33vw;
    padding: 0 5.07vw;
    border-radius: 0.67vw;
    font-size: 3.47vw;
  }

  .sp-contact .contact-field--name {
    top: 129.73vw;
  }

  .sp-contact .contact-field--email {
    top: 158.8vw;
  }

  .sp-contact .contact-field--url {
    top: 188.13vw;
  }

  .sp-contact .contact-submit {
    left: 19.2vw;
    top: 213.47vw;
    width: 61.6vw;
    height: 13.33vw;
    gap: 3.2vw;
    padding: 0 7vw 0 8.5vw;
    font-size: 4vw;
  }

  .sp-contact .contact-message {
    left: 5.33vw;
    top: 229.2vw;
    width: 89.33vw;
    font-size: 3.2vw;
    line-height: 1.6;
    text-align: center;
  }

  .sp-contact .contact-submit__arrow {
    width: 4.27vw;
    height: 2.93vw;
  }

  .sp-contact .contact-submit__arrow::before {
    height: 0.27vw;
  }

  .sp-contact .contact-submit__arrow::after {
    width: 1.73vw;
    height: 1.73vw;
    border-top-width: 0.27vw;
    border-right-width: 0.27vw;
  }
}

.footer {
  position: relative;
  overflow: hidden;
  background: #231815;
  color: #fff;
  font-weight: 700;
  letter-spacing: 0.06em;
}

.footer a {
  color: inherit;
  text-decoration: none;
}

.footer a:focus-visible {
  outline: 3px solid #eb5f20;
  outline-offset: 5px;
}

.pc-footer {
  height: 303px;
  aspect-ratio: auto;
}

.pc-footer .footer-nav {
  position: absolute;
  left: 88px;
  top: 143px;
  display: flex;
  gap: 18px;
  align-items: center;
  font-family: "sweet-sans-pro", sans-serif;
  font-size: 16px;
  line-height: 1.3;
  white-space: nowrap;
}

.pc-footer .footer-info {
  position: absolute;
  left: 812px;
  top: 66px;
  width: 420px;
}

.footer-logo {
  margin: 0;
  font-family: "sweet-sans-pro", sans-serif;
  font-size: 31px;
  line-height: 1;
  letter-spacing: 0.06em;
  white-space: nowrap;
}

.pc-footer .footer-logo span {
  margin-left: 9px;
  font-family: "Noto Sans JP", "Hiragino Kaku Gothic ProN", "Yu Gothic", sans-serif;
  font-size: 12px;
  letter-spacing: 0.04em;
  vertical-align: 0.18em;
}

.footer-company {
  margin: 0;
}

.footer-company div {
  display: flex;
  margin: 0;
}

.footer-company dt,
.footer-company dd {
  margin: 0;
}

.pc-footer .footer-company {
  margin-top: 29px;
}

.pc-footer .footer-company div + div {
  margin-top: 8px;
}

.pc-footer .footer-company dt,
.pc-footer .footer-company dd {
  font-size: 14px;
  line-height: 1.3;
}

.pc-footer .footer-company dt {
  width: 74px;
}

.pc-footer .footer-company dd {
  white-space: nowrap;
}

.footer-cta {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 166px;
  height: 40px;
  margin-top: 18px;
  border-radius: 999px;
  background: #eb5f20;
  font-size: 13px;
  line-height: 1;
  letter-spacing: 0.03em;
}

@media (max-width: 767px) {
  .sp-footer {
    height: 138.27vw;
    aspect-ratio: auto;
    background: #231815;
  }

  .sp-footer .footer-nav {
    position: absolute;
    left: 22vw;
    top: 15.33vw;
    display: grid;
    grid-template-columns: 24vw 30vw;
    column-gap: 9.2vw;
    row-gap: 4.8vw;
    font-family: "sweet-sans-pro", sans-serif;
    font-size: 3.73vw;
    line-height: 1.3;
  }

  .sp-footer .footer-info {
    position: absolute;
    left: 0;
    right: 0;
    top: 58.67vw;
    text-align: center;
  }

  .sp-footer .footer-logo {
    font-size: 7.47vw;
    line-height: 1.1;
    letter-spacing: 0.06em;
  }

  .footer-kana {
    margin: 4.8vw 0 0;
    font-size: 3.33vw;
    line-height: 1.5;
    letter-spacing: 0.08em;
  }

  .sp-footer .footer-company {
    margin-top: 7.47vw;
  }

  .sp-footer .footer-company div {
    display: block;
  }

  .sp-footer .footer-company div + div {
    margin-top: 4.27vw;
  }

  .sp-footer .footer-company dt {
    margin-bottom: 2.4vw;
    font-size: 2.67vw;
    line-height: 1.5;
  }

  .sp-footer .footer-company dd {
    font-size: 3.2vw;
    line-height: 1.5;
    letter-spacing: 0.07em;
  }
}

/* Full-bleed section backgrounds while keeping the 1280px design canvas centered. */
.page > .slice {
  --slice-bleed-bg: transparent;
  --slice-bleed-bg-attachment: scroll;
  --slice-bleed-bg-position: center center;
  --slice-bleed-bg-size: auto;
  isolation: isolate;
  overflow: visible;
}

.page > .slice::after {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 50%;
  z-index: -3;
  width: 100vw;
  min-width: 100%;
  background: var(--slice-bleed-bg);
  background-attachment: var(--slice-bleed-bg-attachment);
  background-position: var(--slice-bleed-bg-position);
  background-size: var(--slice-bleed-bg-size);
  content: "";
  pointer-events: none;
  transform: translateX(-50%);
}

.page > .hero {
  --slice-bleed-bg: #f2ebe5;
  overflow: hidden;
}

.page > .concept {
  --slice-bleed-bg:
    linear-gradient(rgba(35, 24, 21, 0.74), rgba(35, 24, 21, 0.74)),
    url("assets/concept/background.webp");
  --slice-bleed-bg-attachment: fixed;
  --slice-bleed-bg-position: center center;
  --slice-bleed-bg-size: cover;
}

.page > .work,
.page > .case {
  --slice-bleed-bg: #eb5f20;
}

.page > .case::before {
  top: 0;
  right: auto;
  bottom: 0;
  left: 50%;
  width: 100vw;
  transform: translateX(-50%);
}

.page > .approach {
  --slice-bleed-bg: #f4ece5;
}

.page > .journal {
  --slice-bleed-bg: #fff;
}

.page > .company {
  --slice-bleed-bg: #f4f4f4;
}

.page > .who {
  --slice-bleed-bg: linear-gradient(
    to bottom,
    #fff 0,
    #fff 1354px,
    #f4ede8 1354px,
    #f4ede8 2295px,
    #eb5f20 2295px,
    #eb5f20 100%
  );
}

@media (max-width: 767px) {
  .page > .who {
    --slice-bleed-bg: linear-gradient(
      to bottom,
      #fff 0,
      #fff 462.33vw,
      #f4ede8 462.33vw,
      #f4ede8 682.2vw,
      #eb5f20 682.2vw,
      #eb5f20 100%
    );
  }
}

.page > .contact {
  --slice-bleed-bg: var(--contact-bg);
}

.page > .pc-contact {
  --slice-bleed-bg: linear-gradient(to bottom, var(--contact-bg) 0 890px, #fff 890px 100%);
}

.page > .footer {
  --slice-bleed-bg: #231815;
}

.work-marquee {
  width: 100vw;
}

.hero-nav,
.concept-heading h2,
.work-sticky h2,
.case-heading h2,
.approach-heading h2,
.approach-card__num,
.approach-card h3,
.journal-heading h2,
.journal-card__date,
.journal-more,
.company-heading h2,
.who-title,
.contact-copy h2,
.footer-nav,
.footer-logo {
  font-family: "sweet-sans-pro", sans-serif;
  font-weight: 800;
  font-style: normal;
}
