/* =========================================================
   Shannon LLC — page-specific styles (hero, services, etc.)
   ========================================================= */

/* ----------------- Reveal on scroll (subtle fade + rise) ----------------- */
[data-reveal] {
  opacity: 0;
  transform: translate3d(0, 16px, 0);
  transition:
    opacity .8s cubic-bezier(.2, .6, .2, 1),
    transform .8s cubic-bezier(.2, .6, .2, 1);
  transition-delay: var(--d, 0s);
  will-change: opacity, transform;
}
[data-reveal].is-in {
  opacity: 1;
  transform: none;
}

/* When JS is disabled, show everything — no need to scroll-trigger */
.no-js [data-reveal] { opacity: 1; transform: none; }

@media (prefers-reduced-motion: reduce) {
  [data-reveal] { opacity: 1 !important; transform: none !important; transition: none !important; }
}

/* ===================================================================
   HERO
   =================================================================== */
.hero {
  position: relative;
  padding: clamp(80px, 12vw, 140px) 0 clamp(80px, 10vw, 120px);
  overflow: hidden;
  isolation: isolate;
}

.hero__bg {
  position: absolute;
  inset: 0;
  z-index: -1;
  pointer-events: none;
  overflow: hidden;
  background-image:
    linear-gradient(to right, rgba(17,19,24,.045) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(17,19,24,.045) 1px, transparent 1px);
  background-size: 72px 72px;
  background-position: center center;
  animation: gridDrift 24s linear infinite;
  -webkit-mask-image: radial-gradient(ellipse 100% 90% at 50% 50%, #000 55%, transparent 100%);
          mask-image: radial-gradient(ellipse 100% 90% at 50% 50%, #000 55%, transparent 100%);
}
@keyframes gridDrift {
  from { background-position: 0 0; }
  to   { background-position: 72px 72px; }
}
.hero__bg svg {
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  width: min(1600px, 160vw);
  height: auto;
  opacity: .85;
  filter: blur(.2px);
}
.hero__bg::before {
  /* very soft vignette in the very center only, to avoid grid interfering with headline */
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse 40% 28% at 50% 45%, rgba(255,255,255,.6), transparent 70%);
  pointer-events: none;
}

/* Hero particle layer (particles.js canvas) */
.hero__particles {
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
}
.hero__particles canvas {
  display: block;
  width: 100% !important;
  height: 100% !important;
}

@media (prefers-reduced-motion: reduce) {
  .hero__bg { animation: none !important; }
  .hero__particles { display: none; }
}

.hero__inner {
  position: relative;
  max-width: 980px;
  margin: 0 auto;
}

.hero__headline {
  font-family: var(--font-jp);
  font-weight: 600;
  font-size: clamp(44px, 8vw, 104px);
  line-height: 1.12;
  letter-spacing: -.02em;
  color: var(--ink);
  margin: 0 0 32px;
  text-wrap: balance;
}
.hero__headline .line { display: block; }
.hero__headline .grad-text { display: inline; }

.hero__sub {
  font-size: 18px;
  color: var(--muted);
  max-width: 640px;
  margin: 0 0 48px;
  text-wrap: pretty;
  line-height: 1.9;
}

.hero__ctas { display: flex; gap: 12px; flex-wrap: wrap; }
@media (max-width: 720px) {
  .hero__ctas { flex-wrap: nowrap; }
  .hero__ctas .btn { flex: 1 1 0; padding: 0 14px; min-width: 0; font-size: 13px; }
  .hero__ctas .btn .arrow { width: 12px; height: 12px; }
}

/* ===================================================================
   SERVICES (2-up)
   =================================================================== */
.services {
  /* 6-col base so 5 cards lay out as 3 + 2 with the bottom row centered.
     Each card spans 2 cols → 3 cards = 6 cols (full row);
     2 cards in last row also span 2 cols each (4 cols), and the first
     of those is offset to start at column 2 to center it. */
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 24px;
}
.services > .service-card { grid-column: span 2; }
.services > .service-card:nth-child(4) { grid-column: 2 / span 2; }
@media (max-width: 1080px) {
  .services { grid-template-columns: 1fr 1fr; }
  .services > .service-card { grid-column: auto; }
  .services > .service-card:nth-child(4) { grid-column: auto; }
  /* Last (5th) card spans both columns so it doesn't sit alone */
  .services > .service-card:last-child { grid-column: 1 / -1; }
}
@media (max-width: 640px) {
  .services { grid-template-columns: 1fr; }
  .services > .service-card:last-child { grid-column: auto; }
}

.service-card {
  position: relative;
  isolation: isolate;
  padding: 48px 44px 44px;
  border: 1px solid var(--line);
  border-radius: 24px;
  background: #fff;
  transition: transform .25s ease, box-shadow .3s ease, border-color .25s ease;
  display: flex;
  flex-direction: column;
  /* As a link */
  color: inherit;
  text-decoration: none;
}
.service-card:hover {
  transform: translateY(-2px);
  border-color: rgba(17,19,24,.14);
  box-shadow: 0 30px 60px -30px rgba(17,19,24,.22);
}
/* Gradient outline frame slides in from the left on hover (whole-card affordance) */
.service-card::after {
  content: "";
  position: absolute;
  inset: -2px;
  border-radius: inherit;
  padding: 2px;
  background: var(--grad);
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
          mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
          mask-composite: exclude;
  z-index: 1;
  pointer-events: none;
  clip-path: inset(0 100% 0 0);
  transition: clip-path .45s cubic-bezier(.22,.61,.36,1);
}
.service-card:hover::after { clip-path: inset(0 0 0 0); }
/* The CTA inside the card is just a visual pointer — the card itself is the link */
.service-card__cta {
  margin-top: auto;
  border-bottom: 0 !important;
  background-image: none !important;
  padding-bottom: 0 !important;
}
.service-card:hover .service-card__cta { gap: 12px; }

.service-card__num {
  font-family: var(--font-ui);
  font-size: 13px;
  font-weight: 500;
  color: var(--muted);
  letter-spacing: .04em;
  margin-bottom: 36px;
  display: flex;
  align-items: center;
  gap: 14px;
}
.service-card__num::before {
  content: "";
  width: 28px;
  height: 1px;
  background: var(--grad);
  display: inline-block;
}

.service-card h3 {
  font-size: 28px;
  line-height: 1.35;
  font-weight: 600;
  color: var(--ink);
  margin: 0 0 18px;
  letter-spacing: -.01em;
}
.service-card p {
  color: var(--muted);
  font-size: 15.5px;
  margin: 0 0 32px;
  line-height: 1.85;
}
.service-card ul {
  list-style: none;
  padding: 0;
  margin: 0 0 36px;
  font-size: 14.5px;
  color: var(--ink-2);
  border-top: 1px solid var(--line-soft, #ececec);
}
.service-card li {
  display: flex;
  gap: 14px;
  align-items: center;
  padding: 14px 0;
  border-bottom: 1px solid var(--line-soft, #ececec);
}
.service-card li::before {
  content: "";
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: var(--ink);
  flex: 0 0 5px;
  opacity: .4;
}

/* ===================================================================
   REASONS
   =================================================================== */
.reasons {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1px;
  background: var(--line);
  border: 1px solid var(--line);
  border-radius: 18px;
  overflow: hidden;
}
@media (max-width: 960px) { .reasons { grid-template-columns: 1fr 1fr; } }
@media (max-width: 560px) { .reasons { grid-template-columns: 1fr; } }

.reason {
  background: #fff;
  padding: 40px 32px 36px;
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.reason__num {
  font-family: var(--font-ui);
  font-size: 48px;
  font-weight: 600;
  line-height: 1;
  letter-spacing: -.02em;
  color: transparent;
  background: var(--grad);
  -webkit-background-clip: text;
          background-clip: text;
}
.reason__num::after {
  content: "";
  display: block;
  width: 28px;
  height: 1px;
  margin-top: 14px;
  background: var(--grad);
}
.reason h3 {
  font-size: 17px;
  line-height: 1.5;
  font-weight: 600;
  color: var(--ink);
  margin: 0;
}
.reason p {
  color: var(--muted);
  font-size: 14px;
  line-height: 1.85;
  margin: 0;
}

/* ===================================================================
   TECH STACK — tag chips
   =================================================================== */
.tag {
  display: inline-block;
  font-family: var(--font-ui);
  font-size: 13px;
  color: var(--ink);
  padding: 6px 12px;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: #fff;
  text-decoration: none;
  transition: border-color .15s ease, background .15s ease;
}
a.tag:hover { border-color: rgba(17,19,24,.18); background: var(--bg-alt, #f7f7f8); }

/* ===================================================================
   NEWS TICKER — single-line latest news between hero and services
   =================================================================== */
.news-ticker {
  background: #fff;
  border-bottom: 1px solid var(--line);
}
.news-ticker__inner {
  display: flex;
  align-items: center;
  padding: 18px 0;
  font-size: 14px;
}
.news-ticker__link {
  flex: 1 1 auto;
  display: flex;
  align-items: center;
  gap: 18px;
  min-width: 0;
  color: var(--ink);
  text-decoration: none;
  transition: color .2s ease;
}
.news-ticker__link:hover { color: var(--ink-3); }
.news-ticker__link:hover .news-ticker__arrow { transform: translateX(3px); }
.news-ticker__date {
  flex: 0 0 auto;
  font-family: var(--font-ui);
  font-size: 13px;
  color: var(--ink-3);
  letter-spacing: .02em;
}
.news-ticker__cat {
  flex: 0 0 auto;
  font-family: var(--font-ui);
  font-size: 11.5px;
  font-weight: 500;
  letter-spacing: .04em;
  padding: 3px 10px;
  border: 1px solid var(--line);
  border-radius: 999px;
  color: var(--ink-3);
  background: #fff;
  white-space: nowrap;
}
.news-ticker__title {
  flex: 1 1 auto;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  text-decoration: underline;
  text-decoration-color: var(--line);
  text-decoration-thickness: 1px;
  text-underline-offset: 4px;
  transition: text-decoration-color .2s ease;
}
.news-ticker__link:hover .news-ticker__title {
  text-decoration-color: currentColor;
}
.news-ticker__arrow {
  flex: 0 0 auto;
  transition: transform .2s ease;
  color: var(--ink-3);
}
@media (max-width: 720px) {
  .news-ticker { padding: 0 16px; }
  .news-ticker__inner { padding: 12px 0; gap: 10px; font-size: 13px; }
  .news-ticker__link { gap: 10px; }
  .news-ticker__date { font-size: 12px; }
  .news-ticker__cat { display: none; }
  .news-ticker__title { font-size: 13px; }
  .news-ticker__arrow { width: 12px; height: 12px; }
}

/* ===================================================================
   SUB-SERVICES — Detailed sub-offerings on a service page (e.g. Infra)
   =================================================================== */
.sub-services {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 22px;
  margin-top: 40px;
}
.sub-services > .sub-service:nth-child(7) { grid-column: 1 / -1; }
@media (max-width: 860px) {
  .sub-services { grid-template-columns: 1fr; }
  .sub-services > .sub-service:nth-child(7) { grid-column: auto; }
}
.sub-service {
  position: relative;
  padding: 28px 28px 24px;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 18px;
  display: flex;
  flex-direction: column;
  gap: 14px;
  transition: border-color .2s ease, box-shadow .25s ease;
}
.sub-service:hover {
  border-color: rgba(17,19,24,.16);
  box-shadow: 0 18px 40px -28px rgba(17,19,24,.18);
}
.sub-service > header {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 10px;
}
.sub-service__num {
  font-family: var(--font-ui);
  font-size: 12px;
  font-weight: 600;
  letter-spacing: .08em;
  color: transparent;
  background: var(--grad);
  -webkit-background-clip: text;
          background-clip: text;
}
.sub-service__cat {
  font-family: var(--font-ui);
  font-size: 12px;
  letter-spacing: .04em;
  color: var(--ink-3);
  text-transform: uppercase;
}
.sub-service header h3 {
  flex: 1 1 100%;
  font-size: 19px;
  font-weight: 600;
  color: var(--ink);
  margin: 4px 0 0;
}
.sub-service > p {
  font-size: 14.5px;
  line-height: 1.85;
  color: var(--muted);
  margin: 0;
}
.sub-service__list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 6px 16px;
  font-size: 13.5px;
  color: var(--ink-2);
}
@media (max-width: 520px) { .sub-service__list { grid-template-columns: 1fr; } }
.sub-service__list li {
  position: relative;
  padding-left: 14px;
  line-height: 1.7;
}
.sub-service__list li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 9px;
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: var(--ink);
  opacity: .35;
}
.sub-service__use {
  margin-top: auto;
  padding-top: 12px;
  border-top: 1px dashed var(--line);
  font-size: 12.5px;
  color: var(--ink-3);
}

/* ===================================================================
   PLAN CARDS — Pricing tiers on service pages
   =================================================================== */
.plan-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  margin-top: 40px;
}
@media (max-width: 860px) { .plan-grid { grid-template-columns: 1fr; } }
.plan {
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 18px;
  padding: 32px 28px;
  display: flex;
  flex-direction: column;
  gap: 16px;
  transition: border-color .2s ease, box-shadow .25s ease, transform .2s ease;
}
.plan:hover {
  border-color: rgba(17,19,24,.16);
  box-shadow: 0 18px 40px -28px rgba(17,19,24,.18);
}
.plan--featured {
  border-color: transparent;
  background:
    linear-gradient(#fff, #fff) padding-box,
    var(--grad) border-box;
  border: 1.5px solid transparent;
  box-shadow: 0 24px 48px -28px rgba(91,108,255,.4);
}
.plan__tag {
  align-self: flex-start;
  font-family: var(--font-ui);
  font-size: 11.5px;
  font-weight: 600;
  letter-spacing: .12em;
  text-transform: uppercase;
  padding: 4px 12px;
  border: 1px solid var(--line);
  border-radius: 999px;
  color: var(--ink-3);
}
.plan--featured .plan__tag {
  border-color: transparent;
  color: #fff;
  background: var(--grad);
}
.plan h3 {
  font-size: 22px;
  font-weight: 600;
  color: var(--ink);
  margin: 0;
}
.plan__price {
  font-size: 22px;
  font-weight: 600;
  color: var(--ink);
  line-height: 1.4;
  margin: 0;
}
.plan__price small {
  display: block;
  font-size: 12.5px;
  font-weight: 400;
  color: var(--ink-3);
  margin-top: 4px;
}
.plan ul {
  list-style: none;
  padding: 0;
  margin: 0;
  font-size: 14px;
  color: var(--ink-2);
}
.plan li {
  padding: 8px 0;
  border-bottom: 1px solid var(--line-soft, #ececec);
}
.plan li:last-child { border-bottom: 0; }

/* ===================================================================
   LOGO MARQUEE — infinite horizontal scroll for Tech Stack
   =================================================================== */
.logo-marquee {
  margin-top: 56px;
  position: relative;
  /* Soft edge fade so chips don't pop in/out abruptly */
  -webkit-mask-image: linear-gradient(to right, transparent 0, #000 8%, #000 92%, transparent 100%);
          mask-image: linear-gradient(to right, transparent 0, #000 8%, #000 92%, transparent 100%);
}
.logo-marquee__row {
  overflow: hidden;
  padding: 14px 0;
}
.logo-marquee__row + .logo-marquee__row { margin-top: 8px; }

.logo-marquee__track {
  display: flex;
  gap: 12px;
  width: max-content;
  animation: marquee-scroll 60s linear infinite;
  animation-play-state: running;
}
.logo-marquee__row--rtl .logo-marquee__track {
  animation-direction: reverse;
  animation-duration: 70s; /* slightly different speed for visual variety */
}

.logo-marquee:hover .logo-marquee__track,
.logo-marquee__track:focus-within {
  animation-play-state: paused;
}

@keyframes marquee-scroll {
  from { transform: translate3d(0, 0, 0); }
  /* Track holds the list duplicated, so -50% loops seamlessly */
  to   { transform: translate3d(-50%, 0, 0); }
}

/* Marquee chip styling (reuses .tech-logo from the original markup) */
.logo-marquee .tech-logo {
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  height: 44px;
  padding: 0 20px;
  font-family: var(--font-ui);
  font-size: 14px;
  font-weight: 500;
  letter-spacing: .01em;
  color: var(--ink);
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 999px;
  white-space: nowrap;
}
.logo-marquee .tech-logo__icon {
  width: 14px;
  height: 14px;
  display: block;
  flex: 0 0 auto;
  object-fit: contain;
}

/* Respect reduced motion */
@media (prefers-reduced-motion: reduce) {
  .logo-marquee__track { animation: none; }
}

/* ===================================================================
   FLOW STEPS
   =================================================================== */
.flow-list {
  list-style: none;
  padding: 0;
  margin: 0;
  border-top: 1px solid var(--line);
}
.flow-row {
  display: grid;
  grid-template-columns: 160px 1fr 200px;
  gap: 40px;
  align-items: baseline;
  padding: 36px 0;
  border-bottom: 1px solid var(--line);
  transition: background .25s ease;
}
@media (max-width: 860px) {
  .flow-row { grid-template-columns: 72px 1fr; gap: 20px; padding: 24px 0; }
  .flow-row__meta { grid-column: 1 / -1; padding-left: 92px; margin-top: -4px; text-align: left; }
}
.flow-row__num {
  font-family: var(--font-ui);
  font-size: clamp(44px, 5.5vw, 72px);
  font-weight: 200;
  line-height: 1;
  letter-spacing: -.02em;
  background: var(--grad);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  font-variant-numeric: tabular-nums;
}
.flow-row__body h4 {
  font-size: 20px;
  font-weight: 600;
  margin: 0 0 8px;
  color: var(--ink);
  letter-spacing: -.005em;
}
.flow-row__body p {
  font-size: 15px;
  color: var(--muted);
  line-height: 1.8;
  margin: 0;
  max-width: 540px;
}
.flow-row__meta {
  font-family: var(--font-ui);
  font-size: 12.5px;
  color: var(--ink-3);
  letter-spacing: .02em;
  text-align: right;
}

/* ===================================================================
   FAQ
   =================================================================== */
.faq-list { display: grid; gap: 12px; }
.faq-item {
  border: 1px solid var(--line);
  border-radius: 14px;
  background: #fff;
  overflow: hidden;
  transition: border-color .2s ease;
}
.faq-item.is-open { border-color: #dadce2; }
.faq-q {
  width: 100%;
  text-align: left;
  padding: 22px 24px;
  font-size: 15px;
  font-weight: 500;
  color: var(--ink);
  font-family: var(--font-jp);
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 20px;
}
.faq-q .icon {
  flex: 0 0 auto;
  width: 20px; height: 20px;
  position: relative;
}
.faq-q .icon::before,
.faq-q .icon::after {
  content: "";
  position: absolute;
  left: 50%; top: 50%;
  background: var(--ink);
  transform: translate(-50%, -50%);
  transition: transform .55s cubic-bezier(.22, .61, .36, 1);
}
.faq-q .icon::before { width: 12px; height: 1.5px; }
.faq-q .icon::after  { width: 1.5px; height: 12px; }
.faq-item.is-open .icon::after { transform: translate(-50%, -50%) scaleY(0); }
.faq-a {
  max-height: 0;
  overflow: hidden;
  transition: max-height .55s cubic-bezier(.22, .61, .36, 1);
}
.faq-item.is-open .faq-a { max-height: 600px; }
.faq-a-inner {
  padding: 0 24px 22px;
  color: var(--muted);
  font-size: 14px;
  line-height: 1.85;
}

/* ===================================================================
   PAGE HEADER (subpages)
   =================================================================== */
.page-head {
  padding: clamp(80px, 10vw, 120px) 0 clamp(40px, 6vw, 64px);
  border-bottom: 1px solid var(--line);
  background: #fff;
  position: relative;
  overflow: hidden;
  isolation: isolate;
}
.page-head::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  pointer-events: none;
  background-image:
    linear-gradient(to right, rgba(17,19,24,.045) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(17,19,24,.045) 1px, transparent 1px);
  background-size: 56px 56px;
  background-position: center center;
  -webkit-mask-image: radial-gradient(ellipse 100% 90% at 50% 50%, #000 55%, transparent 100%);
          mask-image: radial-gradient(ellipse 100% 90% at 50% 50%, #000 55%, transparent 100%);
}
.page-head::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  pointer-events: none;
  background:
    radial-gradient(ellipse 40% 60% at 10% 20%, rgba(0,212,228,.05), transparent 60%),
    radial-gradient(ellipse 40% 60% at 90% 30%, rgba(255,61,154,.05), transparent 60%);
}
.page-head__breadcrumb {
  font-family: var(--font-ui);
  font-size: 12px;
  color: var(--muted);
  margin-bottom: 16px;
  letter-spacing: .04em;
}
.page-head__breadcrumb a:hover { color: var(--ink); }
.page-head__breadcrumb span { margin: 0 8px; opacity: .5; }
.page-head h1 {
  font-size: clamp(36px, 5.5vw, 56px);
  font-weight: 600;
  color: var(--ink);
  margin: 0 0 20px;
  letter-spacing: -.015em;
  line-height: 1.2;
  text-wrap: balance;
}
.page-head p {
  font-size: 17px;
  color: var(--muted);
  max-width: 640px;
  margin: 0;
  line-height: 1.85;
}

/* ===================================================================
   Pain points list (subpages)
   =================================================================== */
.pain-list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  column-gap: 56px;
  row-gap: 0;
  margin-top: 36px;
  border-top: 1px solid var(--line);
  counter-reset: pain;
}
@media (max-width: 720px) { .pain-list { grid-template-columns: 1fr; column-gap: 0; } }
.pain {
  counter-increment: pain;
  position: relative;
  padding: 24px 0 24px 56px;
  border-bottom: 1px solid var(--line);
  color: var(--ink-2);
  font-size: 15px;
  line-height: 1.85;
}
.pain::before {
  content: counter(pain, decimal-leading-zero);
  position: absolute;
  left: 0;
  top: 26px;
  font-family: var(--font-ui);
  font-size: 13px;
  font-weight: 600;
  letter-spacing: .08em;
  color: transparent;
  background: var(--grad);
  -webkit-background-clip: text;
          background-clip: text;
}

/* Menu grid */
.menu-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}
@media (max-width: 860px) { .menu-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 560px) { .menu-grid { grid-template-columns: 1fr; } }
.menu-item {
  padding: 28px;
  border: 1px solid var(--line);
  border-radius: 14px;
  background: #fff;
}
.menu-item__num {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--muted);
  letter-spacing: .1em;
  margin-bottom: 10px;
}
.menu-item h4 {
  font-size: 16px;
  font-weight: 600;
  margin: 0 0 8px;
  color: var(--ink);
}
.menu-item p {
  font-size: 13px;
  color: var(--muted);
  line-height: 1.75;
  margin: 0;
}

/* ===================================================================
   ABOUT PAGE
   =================================================================== */
.about-grid {
  display: grid;
  grid-template-columns: 220px 1fr;
  gap: 0;
  border: 1px solid var(--line);
  border-radius: 16px;
  background: #fff;
  overflow: hidden;
}
.about-grid dt,
.about-grid dd { padding: 20px 24px; border-bottom: 1px solid var(--line); margin: 0; font-size: 14px; line-height: 1.7; }
.about-grid dt {
  background: var(--bg-alt);
  font-family: var(--font-ui);
  font-size: 12px;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--muted);
  border-right: 1px solid var(--line);
}
.about-grid dd { color: var(--ink-3); }
.about-grid dt:last-of-type,
.about-grid dd:last-of-type { border-bottom: 0; }
@media (max-width: 640px) {
  .about-grid { grid-template-columns: 1fr; }
  .about-grid dt { border-right: 0; }
}

/* ===================================================================
   CONTACT PAGE FORM
   =================================================================== */
.contact-layout {
  display: grid;
  grid-template-columns: 1fr 320px;
  gap: 56px;
}
@media (max-width: 860px) { .contact-layout { grid-template-columns: 1fr; gap: 40px; } }

.contact-form {
  display: grid;
  gap: 20px;
}

.contact-side {
  display: grid;
  gap: 20px;
  padding: 28px;
  border-radius: 16px;
  border: 1px solid var(--line);
  background: var(--bg-alt);
  height: fit-content;
  font-family: var(--font-ui);
}
.contact-side h4 {
  font-size: 13px;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--muted);
  margin: 0;
  font-weight: 500;
}
.contact-side .row .k { font-size: 12px; color: var(--muted); margin-bottom: 4px; }
.contact-side .row .v { font-size: 15px; color: var(--ink); font-weight: 500; word-break: break-all; }
.contact-side .divider { height: 1px; background: var(--line); }

/* ===================================================================
   reCAPTCHA — hide floating badge (disclaimer is shown inside the form)
   =================================================================== */
.grecaptcha-badge {
  visibility: hidden !important;
}

/* ===================================================================
   CONTACT INTRO / NOTICE — copy blocks above the CF7 form
   =================================================================== */
.contact-intro {
  margin: 0 0 56px;
}
.contact-intro p {
  font-size: 16px;
  line-height: 1.95;
  color: var(--ink-2);
  margin: 0 0 14px;
}
.contact-intro p:last-child { margin-bottom: 0; }

/* ===================================================================
   CONTACT FORM 7 — match site typography / inputs
   =================================================================== */
.wpcf7 {
  font-family: var(--font-jp);
}
.wpcf7-form > p {
  margin: 0 0 22px;
  font-size: 14px;
  font-weight: 500;
  color: var(--ink);
  line-height: 1.6;
}
.wpcf7-form > p:last-of-type { margin-bottom: 0; }
.wpcf7-form label {
  display: block;
  font-size: 13px;
  font-weight: 600;
  color: var(--ink);
  letter-spacing: .02em;
  margin-bottom: 6px;
}
.wpcf7-form-control-wrap {
  display: block;
  margin-top: 4px;
}
input.wpcf7-form-control:not([type="submit"]):not([type="checkbox"]):not([type="radio"]),
textarea.wpcf7-form-control,
select.wpcf7-form-control {
  display: block;
  width: 100%;
  padding: 12px 14px;
  font-family: inherit;
  font-size: 15px;
  line-height: 1.6;
  color: var(--ink);
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 10px;
  transition: border-color .15s ease, box-shadow .15s ease;
  box-sizing: border-box;
}
input.wpcf7-form-control:not([type="submit"]):not([type="checkbox"]):not([type="radio"]):focus,
textarea.wpcf7-form-control:focus,
select.wpcf7-form-control:focus {
  outline: none;
  border-color: rgba(91,108,255,.55);
  box-shadow: 0 0 0 4px rgba(91,108,255,.10);
}
.wpcf7-form textarea.wpcf7-form-control {
  height: 120px;
  min-height: 80px;
  resize: vertical;
}
.wpcf7-form-control[type="checkbox"],
.wpcf7-form-control[type="radio"] {
  margin-right: 6px;
  accent-color: #5B6CFF;
}
.wpcf7-list-item {
  display: inline-block;
  margin: 0 16px 0 0;
  font-size: 14px;
}

/* Required marker — small red badge */
.wpcf7-form .wpcf7-required-marker,
.wpcf7-form span.required,
.wpcf7-form .required {
  display: inline-block;
  vertical-align: 2px;
  margin-left: 8px;
  padding: 2px 7px;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .08em;
  line-height: 1.4;
  color: #fff;
  background: #e25060;
  border-radius: 4px;
  text-indent: 0;
}

/* Group label (radio header) */
.wpcf7-form .form-group-label {
  display: block;
  font-size: 13px;
  font-weight: 600;
  color: var(--ink);
  letter-spacing: .02em;
  margin-bottom: 10px !important;
}

/* Radio group as card-style choice list */
.wpcf7-form .contact-radio-group {
  margin: 0 0 22px !important;
}
.wpcf7-form .contact-radio-group .wpcf7-radio {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}
@media (max-width: 560px) {
  .wpcf7-form .contact-radio-group .wpcf7-radio { grid-template-columns: 1fr; }
}
.wpcf7-form .contact-radio-group .wpcf7-list-item {
  display: block;
  margin: 0;
  padding: 0;
}
.wpcf7-form .contact-radio-group .wpcf7-list-item label {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px 14px;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: #fff;
  font-size: 14px;
  font-weight: 500;
  color: var(--ink-2);
  cursor: pointer;
  transition: border-color .15s ease, background .15s ease, color .15s ease;
  margin: 0;
}
.wpcf7-form .contact-radio-group .wpcf7-list-item label:hover {
  border-color: rgba(91,108,255,.4);
  background: rgba(91,108,255,.03);
  color: var(--ink);
}
.wpcf7-form .contact-radio-group input[type="radio"] {
  margin: 0;
  flex: 0 0 auto;
}
.wpcf7-form .contact-radio-group input[type="radio"]:checked + .wpcf7-list-item-label,
.wpcf7-form .contact-radio-group label:has(input[type="radio"]:checked) {
  border-color: rgba(91,108,255,.55);
  background: rgba(91,108,255,.06);
  color: var(--ink);
}

/* Privacy consent — large clickable card */
.wpcf7-form .contact-consent {
  margin: 32px 0 12px !important;
  padding: 0;
}
.wpcf7-form .contact-consent .wpcf7-list-item {
  display: block;
  margin: 0;
  padding: 0;
}
.wpcf7-form .contact-consent .wpcf7-list-item > label {
  display: flex;
  align-items: center;
  gap: 14px;
  width: 100%;
  margin: 0;
  padding: 16px 18px;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: #fff;
  font-size: 14px;
  font-weight: 500;
  color: var(--ink);
  cursor: pointer;
  transition: border-color .15s ease, background .15s ease, box-shadow .15s ease;
  box-sizing: border-box;
}
.wpcf7-form .contact-consent .wpcf7-list-item > label:hover {
  border-color: rgba(91,108,255,.4);
  background: rgba(91,108,255,.03);
}
.wpcf7-form .contact-consent .wpcf7-list-item > label:has(input[type="checkbox"]:checked) {
  border-color: rgba(91,108,255,.55);
  background: rgba(91,108,255,.06);
  box-shadow: 0 0 0 3px rgba(91,108,255,.08);
}
.wpcf7-form .contact-consent input[type="checkbox"] {
  flex: 0 0 auto;
  width: 20px;
  height: 20px;
  margin: 0;
  accent-color: #5B6CFF;
  cursor: pointer;
}
.wpcf7-form .contact-consent .wpcf7-list-item-label {
  flex: 1 1 auto;
  line-height: 1.5;
}
.wpcf7-form .contact-consent a {
  color: var(--ink);
  text-decoration: underline;
  text-underline-offset: 3px;
  font-weight: 600;
}
.wpcf7-form .contact-consent a:hover { color: #5B6CFF; }

/* Submit button — match .btn--primary visually */
.wpcf7-form p:has(input.wpcf7-submit) {
  text-align: center;
  margin-top: 32px;
}
.wpcf7-submit {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 220px;
  padding: 14px 28px;
  font-family: var(--font-ui);
  font-size: 15px;
  font-weight: 600;
  letter-spacing: .02em;
  color: #fff;
  background: var(--grad);
  background-size: 220% 100%;
  background-position: 30% 50%;
  border: 0;
  border-radius: 999px;
  cursor: pointer;
  text-shadow: 0 1px 0 rgba(0,0,0,.08);
  box-shadow: 0 14px 28px -12px rgba(91,108,255,.45);
  transition: background-position .25s ease, transform .15s ease, box-shadow .2s ease;
}
.wpcf7-submit:hover {
  background-position: 100% 50%;
  transform: translateY(-1px);
  box-shadow: 0 18px 32px -12px rgba(91,108,255,.5);
}
.wpcf7-submit:active { transform: translateY(0); }
.wpcf7-submit[disabled] { opacity: .6; cursor: not-allowed; }

/* Error / response messages */
.wpcf7-not-valid-tip {
  display: block;
  margin-top: 6px;
  font-size: 12.5px;
  color: #d54158;
  font-weight: 500;
}
.wpcf7-response-output {
  margin: 24px 0 0 !important;
  padding: 14px 16px !important;
  font-size: 14px;
  line-height: 1.6;
  border-radius: 10px;
  border-width: 1px !important;
}
.wpcf7 form.invalid .wpcf7-response-output,
.wpcf7 form.unaccepted .wpcf7-response-output,
.wpcf7 form.payment-required .wpcf7-response-output {
  background: #fef2f3;
  border-color: #f0c2c8 !important;
  color: #b13040;
}
.wpcf7 form.sent .wpcf7-response-output {
  background: #eef9f1;
  border-color: #cfeacf !important;
  color: #1f7a3f;
}

/* Spinner */
.wpcf7-spinner {
  margin-left: 12px;
  vertical-align: middle;
}

/* ===================================================================
   PLATFORM TABSET — keep only the JS-referenced selectors
   (.tabset__tab and .tabset__panel are queried by app.js)
   =================================================================== */
.tabset__tab {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 2px;
  padding: 14px 16px;
  border-radius: 12px;
  background: transparent;
  border: none;
  cursor: pointer;
  color: var(--ink-3);
  text-align: left;
  transition: background .18s ease, color .18s ease, transform .18s ease;
  position: relative;
}
.tabset__tab:hover { background: var(--bg-muted); color: var(--ink); }
.tabset__tab.is-active {
  background: linear-gradient(135deg, rgba(0,212,228,.08), rgba(91,108,255,.08) 50%, rgba(255,61,154,.08));
  color: var(--ink);
  box-shadow: 0 0 0 1px rgba(91,108,255,.18);
}
.tabset__tab.is-active::before {
  content: "";
  position: absolute;
  left: 16px; right: 16px; bottom: 6px;
  height: 2px;
  background: var(--grad);
  border-radius: 2px;
}
.tabset__panel {
  display: none;
  animation: tabFade .3s ease both;
}
.tabset__panel.is-active { display: block; }
@keyframes tabFade {
  from { opacity: 0; transform: translateY(6px); }
  to   { opacity: 1; transform: none; }
}

/* ===================================================================
   CASES — list grid & detail
   =================================================================== */
.filter-bar {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 0 0 32px;
}
.filter-chip {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 14px 8px 16px;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 999px;
  font-family: var(--font-ui);
  font-size: 13px;
  color: var(--ink-2);
  cursor: pointer;
  transition: background .15s ease, color .15s ease, border-color .15s ease;
}
.filter-chip:hover { background: var(--bg-muted); color: var(--ink); }
.filter-chip.is-active {
  background: var(--ink);
  color: #fff;
  border-color: var(--ink);
}
.filter-chip__n {
  font-size: 11px;
  padding: 2px 7px;
  border-radius: 999px;
  background: rgba(17,19,24,.08);
  color: inherit;
}
.filter-chip.is-active .filter-chip__n { background: rgba(255,255,255,.18); }

.cases-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}
.case-card {
  position: relative;
  isolation: isolate;
  display: flex;
  flex-direction: column;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 18px;
  overflow: hidden;
  color: var(--ink);
  transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
  --accent: #5B6CFF;
}
.case-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 20px 40px -20px rgba(17,19,24,.14), 0 4px 12px -6px rgba(17,19,24,.08);
  border-color: rgba(91,108,255,.25);
}
/* Gradient outline frame slides in from the left on hover */
.case-card::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  padding: 2px;
  background: var(--grad);
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
          mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
          mask-composite: exclude;
  z-index: 3;
  pointer-events: none;
  clip-path: inset(0 100% 0 0);
  transition: clip-path .45s cubic-bezier(.22,.61,.36,1);
}
.case-card:hover::after { clip-path: inset(0 0 0 0); }
.case-card.is-hidden { display: none; }
.case-card__img {
  aspect-ratio: 16 / 10;
  overflow: hidden;
  background: var(--bg-muted);
  position: relative;
}
.case-card__img svg,
.case-card__img img { display: block; width: 100%; height: 100%; object-fit: cover; }
.case-card__img img {
  transition: transform .6s ease;
}
.case-card:hover .case-card__img img { transform: scale(1.04); }
.case-card__img::after {
  content: "";
  position: absolute;
  left: 20px; bottom: 16px;
  width: 28px; height: 4px;
  background: var(--accent);
  border-radius: 4px;
  opacity: .8;
}
.case-card__body {
  padding: 22px 22px 20px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  flex: 1;
}
.case-card__meta {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-family: var(--font-ui);
  font-size: 11px;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--muted);
}
.case-card__industry { color: var(--accent); font-weight: 600; }
.case-card__title {
  font-family: var(--font-jp);
  font-size: 18px;
  font-weight: 600;
  letter-spacing: -.005em;
  line-height: 1.5;
  margin: 0;
  color: var(--ink);
  text-wrap: pretty;
}
.case-card__summary {
  font-size: 13.5px;
  color: var(--ink-3);
  line-height: 1.75;
  margin: 0;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.case-card__tags {
  display: flex; flex-wrap: wrap; gap: 6px;
  margin-top: auto;
}
.case-card__tags .tag {
  font-size: 11px;
  padding: 3px 9px;
}
.case-card__foot {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-top: 14px;
  border-top: 1px solid var(--line);
  font-family: var(--font-ui);
  font-size: 13px;
  color: var(--ink-2);
}
.case-card__arrow {
  width: 30px; height: 30px;
  border-radius: 50%;
  display: inline-flex; align-items: center; justify-content: center;
  background: var(--bg-muted);
  color: var(--ink-2);
  transition: background .2s ease, color .2s ease, transform .2s ease;
}
.case-card:hover .case-card__arrow {
  background: var(--ink);
  color: #fff;
  transform: translateX(2px);
}

@media (max-width: 980px) {
  .cases-grid { grid-template-columns: repeat(2, 1fr); }
}

/* ===== Related cases (used on service pages) ===== */
.related-cases-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}
@media (max-width: 980px) {
  .related-cases-grid { grid-template-columns: repeat(2, 1fr); }
  .related-cases-grid > :nth-child(3) { display: none; }
}
@media (max-width: 640px) {
  .related-cases-grid { grid-template-columns: 1fr; }
  .related-cases-grid > :nth-child(3) { display: block; }
  .cases-grid { grid-template-columns: 1fr; }
}

/* ===================================================================
   NEWS LIST (お知らせ一覧)
   =================================================================== */
.news-list {
  list-style: none;
  padding: 0;
  margin: 0;
  border-top: 1px solid var(--line);
}
.news-list > li {
  border-bottom: 1px solid var(--line);
}
.news-card {
  display: grid;
  grid-template-columns: 110px 96px 1fr 24px;
  align-items: center;
  gap: 20px;
  padding: 22px 4px;
  color: var(--ink);
  text-decoration: none;
  transition: color .2s ease, background .2s ease;
  position: relative;
}
.news-card:hover { background: var(--bg-alt, #f7f7f8); }
.news-card:hover .news-card__title { color: var(--ink); text-decoration-color: currentColor; }
.news-card:hover::after { transform: translateX(3px); }
.news-card::after {
  content: "";
  width: 14px; height: 14px;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 14 14' fill='none'><path d='M3 7h8m0 0L7.5 3.5M11 7l-3.5 3.5' stroke='%2374757B' stroke-width='1.4' stroke-linecap='round' stroke-linejoin='round'/></svg>");
  background-repeat: no-repeat;
  background-size: contain;
  transition: transform .2s ease;
}
.news-card__date {
  font-family: var(--font-ui);
  font-size: 13px;
  letter-spacing: .04em;
  color: var(--ink-3);
}
.news-card__cat {
  justify-self: start;
  font-family: var(--font-ui);
  font-size: 11.5px;
  font-weight: 500;
  letter-spacing: .04em;
  padding: 4px 10px;
  border: 1px solid var(--line);
  border-radius: 999px;
  color: var(--ink-3);
  background: #fff;
  white-space: nowrap;
}
.news-card__title {
  font-size: 15px;
  font-weight: 500;
  line-height: 1.55;
  color: var(--ink);
  margin: 0;
  text-decoration: underline;
  text-decoration-color: transparent;
  text-underline-offset: 4px;
  transition: text-decoration-color .2s ease;
}
@media (max-width: 720px) {
  .news-card {
    grid-template-columns: 1fr 16px;
    grid-template-rows: auto auto;
    gap: 4px 12px;
    padding: 18px 4px;
  }
  .news-card__date { grid-column: 1 / 2; grid-row: 1; font-size: 12px; }
  .news-card__cat { grid-column: 1 / 2; grid-row: 1; justify-self: end; }
  .news-card__title { grid-column: 1 / 2; grid-row: 2; font-size: 14.5px; }
  .news-card::after { grid-column: 2; grid-row: 1 / span 2; align-self: center; }
}

/* ===================================================================
   CASE DETAIL — long-form article layout
   =================================================================== */
.case-article {
  --accent: #5B6CFF;
  background: #fff;
}
.case-article__header {
  border-bottom: 1px solid var(--line);
  padding: clamp(56px, 8vw, 96px) 0 clamp(32px, 4vw, 48px);
  background: #fff;
}
.case-article__breadcrumb {
  font-family: var(--font-ui);
  font-size: 12px;
  letter-spacing: .04em;
  color: var(--ink-3);
  margin-bottom: 24px;
}
.case-article__breadcrumb a { color: var(--ink-3); text-decoration: none; }
.case-article__breadcrumb a:hover { color: var(--ink); }
.case-article__breadcrumb span { margin: 0 8px; opacity: .55; }
.case-article__industry {
  display: inline-block;
  font-family: var(--font-ui);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: transparent;
  background: var(--grad);
  -webkit-background-clip: text;
          background-clip: text;
  margin-bottom: 16px;
}
.case-article__title {
  font-family: var(--font-jp);
  font-size: clamp(36px, 5.5vw, 56px);
  font-weight: 600;
  line-height: 1.2;
  letter-spacing: -.015em;
  color: var(--ink);
  margin: 0 0 20px;
  text-wrap: balance;
}
.case-article__client {
  font-family: var(--font-ui);
  font-size: 15px;
  color: var(--ink-2);
  margin: 0 0 20px;
  letter-spacing: .01em;
}
.case-article__lead {
  font-size: 17px;
  line-height: 1.95;
  color: var(--ink-2);
  margin: 0 0 28px;
  max-width: 820px;
}
.case-article__tags {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.case-article__body {
  padding-top: clamp(40px, 6vw, 64px);
  padding-bottom: clamp(56px, 8vw, 96px);
}
.case-article__section {
  margin-bottom: 64px;
}
.case-article__section:last-of-type { margin-bottom: 0; }
.case-article__section h2 {
  font-family: var(--font-jp);
  font-size: clamp(28px, 4vw, 44px);
  font-weight: 600;
  line-height: 1.3;
  letter-spacing: -.01em;
  color: var(--ink);
  margin: 0 0 24px;
  text-wrap: balance;
}
.case-article__section > p {
  font-size: 17px;
  line-height: 2;
  color: var(--ink-2);
  margin: 0;
}

/* Approach steps — numbered ordered list */
.case-article__steps {
  list-style: none;
  padding: 0;
  margin: 36px 0 0;
  border-top: 1px solid var(--line);
}
.case-article__steps > li {
  display: grid;
  grid-template-columns: 92px 1fr;
  gap: 24px;
  padding: 26px 0;
  border-bottom: 1px solid var(--line);
  align-items: baseline;
}
.case-article__step-num {
  font-family: var(--font-ui);
  font-size: 32px;
  font-weight: 600;
  line-height: 1;
  color: transparent;
  background: var(--grad);
  -webkit-background-clip: text;
          background-clip: text;
  letter-spacing: -.02em;
}
.case-article__step-text {
  font-size: 17px;
  line-height: 1.9;
  color: var(--ink-2);
}

/* KSF as plain definition list with row dividers */
.case-article__ksf { margin: 0; }
.case-article__ksf > div {
  padding: 16px 0;
  border-bottom: 1px solid var(--line-2, #eef0f3);
}
.case-article__ksf > div:first-child { padding-top: 0; }
.case-article__ksf > div:last-child { border-bottom: 0; padding-bottom: 0; }
.case-article__ksf dt {
  font-size: 17px;
  font-weight: 600;
  color: var(--ink);
  margin: 0 0 6px;
}
.case-article__ksf dd {
  margin: 0;
  font-size: 16px;
  line-height: 1.9;
  color: var(--ink-2);
}

/* Inline CTA — minimal, centered, separated by a thin top rule */
.case-article__inline-cta {
  margin-top: 64px;
  padding: 36px 0 0;
  border-top: 1px solid var(--line);
  text-align: center;
}
.case-article__inline-cta h3 {
  margin: 0 0 12px;
  font-size: clamp(20px, 2.4vw, 24px);
  font-weight: 600;
  color: var(--ink);
}
.case-article__inline-cta p {
  margin: 0 0 24px;
  font-size: 16px;
  color: var(--muted);
}

/* Before / After list */
.ba-list {
  list-style: none;
  padding: 0;
  margin: 24px 0 0;
  border-top: 1px solid var(--line);
  background: #fff;
  border-radius: 16px;
  border: 1px solid var(--line);
  overflow: hidden;
}
.ba-list__row {
  display: grid;
  grid-template-columns: 200px 1fr;
  gap: 24px;
  padding: 22px 28px;
  border-bottom: 1px solid var(--line);
  align-items: center;
}
.ba-list__row:last-child { border-bottom: 0; }
.ba-list__k {
  font-family: var(--font-ui);
  font-size: 12px;
  font-weight: 600;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--ink-3);
}
.ba-list__values {
  display: flex;
  align-items: baseline;
  gap: 16px;
  flex-wrap: wrap;
}
.ba-list__before {
  font-size: 16px;
  color: var(--muted);
  text-decoration: line-through;
  text-decoration-color: rgba(17,19,24,.18);
  text-underline-offset: 4px;
}
.ba-list__arrow {
  font-family: var(--font-ui);
  font-size: 14px;
  color: var(--ink-3);
  opacity: .55;
}
.ba-list__after {
  font-family: var(--font-ui);
  font-size: 22px;
  font-weight: 600;
  letter-spacing: -.01em;
  color: transparent;
  background: var(--grad);
  -webkit-background-clip: text;
          background-clip: text;
}
@media (max-width: 720px) {
  .ba-list__row { grid-template-columns: 1fr; gap: 8px; padding: 20px 22px; }
  .ba-list__after { font-size: 19px; }
}

/* ===================================================================
   PAGINATION (the_posts_pagination / paginate_links)
   =================================================================== */
.pagination,
nav.pagination,
.navigation.pagination {
  margin-top: 56px;
  display: flex;
  justify-content: center;
}
.pagination .nav-links,
.navigation.pagination .nav-links {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
}
.page-numbers {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 40px;
  height: 40px;
  padding: 0 12px;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: #fff;
  color: var(--ink-2);
  font-family: var(--font-ui);
  font-size: 14px;
  text-decoration: none;
  transition: border-color .15s ease, color .15s ease, background .15s ease;
}
.page-numbers:hover { border-color: rgba(17,19,24,.18); color: var(--ink); background: var(--bg-alt, #f7f7f8); }
.page-numbers.current {
  border-color: var(--ink);
  color: #fff;
  background: var(--ink);
}
.page-numbers.dots { border: 0; background: transparent; }
.page-numbers.prev,
.page-numbers.next {
  font-weight: 500;
  letter-spacing: .04em;
}
.pagination .screen-reader-text,
.navigation.pagination .screen-reader-text {
  position: absolute;
  width: 1px; height: 1px;
  overflow: hidden;
  clip: rect(0 0 0 0);
}
/* ===================================================================
   HISTORY LIST — 沿革 timeline (about page)
   =================================================================== */
.history-list {
  list-style: none;
  padding: 0;
  margin: 36px 0 0;
  border-top: 1px solid var(--line);
}
.history-list > li {
  display: grid;
  grid-template-columns: 120px 1fr;
  gap: 28px;
  padding: 28px 0;
  border-bottom: 1px solid var(--line);
  align-items: baseline;
}
.history-list__date {
  font-family: var(--font-ui);
  font-size: 18px;
  font-weight: 600;
  letter-spacing: -.01em;
  background: var(--grad);
  -webkit-background-clip: text;
          background-clip: text;
  color: transparent;
}
.history-list__body strong {
  display: block;
  font-size: 17px;
  color: var(--ink);
  margin: 0 0 6px;
}
.history-list__body p {
  margin: 0;
  font-size: 15px;
  line-height: 1.85;
  color: var(--ink-2);
}
@media (max-width: 720px) {
  .history-list > li { grid-template-columns: 1fr; gap: 6px; padding: 22px 0; }
}

/* ===================================================================
   PROFILE CARD — 代表プロフィール (about page)
   =================================================================== */
.profile-card {
  border: 1px solid var(--line);
  border-radius: 16px;
  padding: clamp(28px, 4vw, 40px);
  background: #fff;
}
.profile-card__head {
  padding-bottom: 24px;
  margin-bottom: 24px;
  border-bottom: 1px solid var(--line);
}
.profile-card__role {
  font-family: var(--font-ui);
  font-size: 12px;
  font-weight: 600;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--ink-3);
  margin: 0 0 8px;
}
.profile-card__name {
  font-family: var(--font-jp);
  font-size: clamp(22px, 2.6vw, 28px);
  font-weight: 600;
  letter-spacing: -.005em;
  color: var(--ink);
  margin: 0;
}
.profile-card__name span {
  font-family: var(--font-ui);
  font-size: 14px;
  font-weight: 500;
  letter-spacing: .02em;
  color: var(--ink-3);
  margin-left: 12px;
}
.profile-card__facts {
  margin: 0;
}
.profile-card__facts > div {
  display: grid;
  grid-template-columns: 140px 1fr;
  gap: 24px;
  padding: 16px 0;
  border-bottom: 1px solid var(--line-2, #eef0f3);
  align-items: baseline;
}
.profile-card__facts > div:first-child { padding-top: 0; }
.profile-card__facts > div:last-child { border-bottom: 0; padding-bottom: 0; }
.profile-card__facts dt {
  font-family: var(--font-ui);
  font-size: 12px;
  font-weight: 600;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--ink-3);
  margin: 0;
}
.profile-card__facts dd {
  margin: 0;
  font-size: 15.5px;
  line-height: 1.85;
  color: var(--ink-2);
}
.career-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  gap: 14px;
}
.career-list > li {
  position: relative;
  padding-left: 16px;
  font-size: 13.5px;
  line-height: 1.7;
}
.career-list > li::before {
  content: "";
  position: absolute;
  left: 0;
  top: .7em;
  width: 6px;
  height: 1px;
  background: var(--ink-3);
  opacity: .55;
}
.career-list > li strong {
  display: block;
  font-size: 14px;
  font-weight: 600;
  color: var(--ink);
  margin-bottom: 2px;
}
.career-list > li span {
  display: block;
  color: var(--ink-3);
}
@media (max-width: 720px) {
  .profile-card__facts > div { grid-template-columns: 1fr; gap: 6px; padding: 18px 0; }
}

/* ===================================================================
   APPROACH LIST — numbered ordered list (service pages)
   =================================================================== */
.approach-list {
  list-style: none;
  padding: 0;
  margin: 36px 0 0;
  border-top: 1px solid var(--line);
}
.approach-list li {
  display: grid;
  grid-template-columns: 92px 1fr;
  gap: 24px;
  align-items: baseline;
  padding: 26px 0;
  border-bottom: 1px solid var(--line);
  font-size: 15px;
  line-height: 1.9;
  color: var(--ink-2);
}
.approach-list__body strong {
  display: block;
  font-size: 17px;
  color: var(--ink);
  margin: 0 0 6px;
}
.approach-list__body p {
  margin: 0;
  color: var(--ink-2);
}
.approach-list__num {
  font-family: var(--font-ui);
  font-size: 32px;
  font-weight: 600;
  line-height: 1;
  letter-spacing: -.02em;
  background: var(--grad);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

/* ===================================================================
   RADIAL VALUES — minimal geometric / line-only (about page)
   =================================================================== */
.radial-values {
  position: relative;
  margin-top: 72px;
  width: 100%;
  height: 560px;
  max-width: 920px;
  margin-left: auto;
  margin-right: auto;
  color: #0A0C16;
}
.radial-values__lines {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  color: #0A0C16;
}

/* ----- Entry animations (fired when .is-in is added by IntersectionObserver) ----- */
/* Lines: drawn via stroke-dashoffset */
.rv-line {
  stroke-dasharray: 800;
  stroke-dashoffset: 800;
  transition: stroke-dashoffset 1100ms cubic-bezier(0.22, 0.61, 0.36, 1);
}
.rv-line--v { stroke-dasharray: 560; stroke-dashoffset: 560; }
.radial-values.is-in .rv-line { stroke-dashoffset: 0; }
.radial-values.is-in .rv-line--v { transition-delay: 120ms; }

/* Ring: scale up from 0 + draw */
.rv-ring {
  stroke-dasharray: 760;
  stroke-dashoffset: 760;
  transform-box: fill-box;
  transform-origin: center;
  transform: scale(0.6);
  opacity: 0;
  transition:
    stroke-dashoffset 1200ms cubic-bezier(0.22, 0.61, 0.36, 1) 280ms,
    transform 900ms cubic-bezier(0.22, 0.61, 0.36, 1) 280ms,
    opacity 600ms ease 280ms;
}
.radial-values.is-in .rv-ring {
  stroke-dashoffset: 0;
  transform: scale(1);
  opacity: 0.18;
}

/* Dots: scale-in stagger */
.rv-dot {
  transform-box: fill-box;
  transform-origin: center;
  transform: scale(0);
  opacity: 0;
  transition: transform 480ms cubic-bezier(0.22, 1.5, 0.36, 1), opacity 320ms ease;
}
.radial-values.is-in .rv-dot { transform: scale(1); opacity: 1; }
.radial-values.is-in .rv-dot--1 { transition-delay: 700ms; }
.radial-values.is-in .rv-dot--2 { transition-delay: 820ms; }
.radial-values.is-in .rv-dot--3 { transition-delay: 940ms; }
.radial-values.is-in .rv-dot--4 { transition-delay: 1060ms; }

/* Dot pulse loop (after entry settles) */
@keyframes rv-dot-pulse {
  0%, 100% { transform: scale(1); opacity: 1; }
  50%      { transform: scale(1.7); opacity: 0.5; }
}
.radial-values.is-in .rv-dot--1 { animation: rv-dot-pulse 3.6s ease-in-out 1.6s infinite; }
.radial-values.is-in .rv-dot--2 { animation: rv-dot-pulse 3.6s ease-in-out 2.5s infinite; }
.radial-values.is-in .rv-dot--3 { animation: rv-dot-pulse 3.6s ease-in-out 3.4s infinite; }
.radial-values.is-in .rv-dot--4 { animation: rv-dot-pulse 3.6s ease-in-out 4.3s infinite; }

/* Center core — thin ring only */
.radial-values__core {
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%) scale(0);
  width: 88px;
  height: 88px;
  border-radius: 50%;
  border: 1px solid rgba(10, 12, 22, 0.45);
  background: #ffffff;
  z-index: 2;
  opacity: 0;
  transition:
    transform 700ms cubic-bezier(0.22, 1.4, 0.36, 1) 200ms,
    opacity 500ms ease 200ms;
  animation: rv-core-breathe 5s ease-in-out 1500ms infinite;
}
.radial-values.is-in .radial-values__core {
  transform: translate(-50%, -50%) scale(1);
  opacity: 1;
}
@keyframes rv-core-breathe {
  0%, 100% { box-shadow: 0 0 0 0 rgba(10,12,22,0); border-color: rgba(10, 12, 22, 0.45); }
  50%      { box-shadow: 0 0 0 8px rgba(10,12,22,0.025); border-color: rgba(10, 12, 22, 0.7); }
}

/* Nodes — text only, no card */
.radial-values__node {
  position: absolute;
  width: 240px;
  background: transparent;
  border: 0;
  padding: 0;
  z-index: 3;
  opacity: 0;
  transition: opacity 600ms ease, transform 700ms cubic-bezier(0.22, 0.61, 0.36, 1);
}
.radial-values.is-in .radial-values__node { opacity: 1; }

.radial-values__node-num,
.radial-values__node-en,
.radial-values__node h3,
.radial-values__node p {
  opacity: 0;
  transform: translateY(8px);
  transition: opacity 500ms ease, transform 500ms cubic-bezier(0.22, 0.61, 0.36, 1);
}
.radial-values.is-in .radial-values__node-num,
.radial-values.is-in .radial-values__node-en,
.radial-values.is-in .radial-values__node h3,
.radial-values.is-in .radial-values__node p {
  opacity: 1;
  transform: translateY(0);
}

/* Per-line stagger inside each node */
.radial-values__node-num { transition-delay: var(--node-delay, 0ms); }
.radial-values__node-en  { transition-delay: calc(var(--node-delay, 0ms) + 90ms); }
.radial-values__node h3  { transition-delay: calc(var(--node-delay, 0ms) + 180ms); }
.radial-values__node p   { transition-delay: calc(var(--node-delay, 0ms) + 270ms); }

/* Per-node base delay (after lines+dots) */
.radial-values__node--top    { --node-delay: 1300ms; }
.radial-values__node--right  { --node-delay: 1450ms; }
.radial-values__node--bottom { --node-delay: 1600ms; }
.radial-values__node--left   { --node-delay: 1750ms; }

.radial-values__node-num {
  font-family: 'Space Grotesk', system-ui, sans-serif;
  font-size: 11px;
  letter-spacing: 0.18em;
  color: rgba(10, 12, 22, 0.4);
  margin-bottom: 4px;
}
.radial-values__node-en {
  font-family: 'Space Grotesk', system-ui, sans-serif;
  font-size: 13px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: #0A0C16;
  margin-bottom: 6px;
}
.radial-values__node h3 {
  font-size: 18px;
  font-weight: 500;
  margin: 0 0 8px;
  letter-spacing: -0.01em;
  color: #0A0C16;
}
.radial-values__node p {
  font-size: 13px;
  line-height: 1.7;
  color: rgba(10, 12, 22, 0.65);
  margin: 0;
}

/* Position each node — top/right/bottom/left, sitting just outside the anchor dots */
.radial-values__node--top {
  left: 50%;
  top: 0;
  transform: translateX(-50%);
  text-align: center;
  width: 280px;
}
.radial-values__node--top h3,
.radial-values__node--bottom h3,
.radial-values__node--top .radial-values__node-en,
.radial-values__node--bottom .radial-values__node-en,
.radial-values__node--top .radial-values__node-num,
.radial-values__node--bottom .radial-values__node-num {
  text-align: center;
}
.radial-values__node--top { top: 80px; }
.radial-values__node--top h3 { display: none; }
.radial-values__node--top,
.radial-values__node--bottom {
  display: flex;
  flex-direction: column;
  align-items: center;
}
.radial-values__node--top h3 { display: block; order: -1; margin: 0 0 4px; }

.radial-values__node--right {
  right: 0;
  top: 50%;
  transform: translateY(-50%);
  text-align: left;
  padding-left: 0;
}

.radial-values__node--bottom {
  left: 50%;
  bottom: 80px;
  transform: translateX(-50%);
  width: 280px;
}
.radial-values__node--bottom h3 { order: -1; margin: 0 0 4px; }

.radial-values__node--left {
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  text-align: right;
}

/* Reduced motion: skip animations */
@media (prefers-reduced-motion: reduce) {
  .rv-line, .rv-line--v, .rv-ring, .rv-dot,
  .radial-values__core, .radial-values__node,
  .radial-values__node-num, .radial-values__node-en,
  .radial-values__node h3, .radial-values__node p {
    transition: none !important;
    animation: none !important;
    opacity: 1 !important;
    transform: none !important;
    stroke-dashoffset: 0 !important;
  }
  .radial-values.is-in .radial-values__core { transform: translate(-50%, -50%) scale(1) !important; }
  .radial-values.is-in .rv-ring { opacity: 0.18 !important; }
}

/* Mobile fallback: stack vertically */
@media (max-width: 760px) {
  .radial-values {
    height: auto;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 28px;
    padding: 0;
    margin-top: 32px;
  }
  .radial-values__lines { display: none; }
  .radial-values__core {
    position: relative;
    left: auto; top: auto;
    transform: none;
    width: 0;
    height: 0;
    border: 0;
    margin: 0;
  }
  .radial-values__node,
  .radial-values__node--top,
  .radial-values__node--right,
  .radial-values__node--bottom,
  .radial-values__node--left {
    position: relative;
    left: auto; right: auto; top: auto; bottom: auto;
    transform: none;
    width: 100%;
    max-width: 420px;
    text-align: left;
    display: block;
    --node-delay: 0ms;
  }
  .radial-values__node--top h3,
  .radial-values__node--bottom h3 {
    display: block;
    order: 0;
    text-align: left;
    margin: 8px 0 8px;
  }
  .radial-values__node--top .radial-values__node-num,
  .radial-values__node--bottom .radial-values__node-num,
  .radial-values__node--top .radial-values__node-en,
  .radial-values__node--bottom .radial-values__node-en {
    text-align: left;
  }
}

/* ===================================================================
   404 PAGE
   =================================================================== */
.page-404 {
  min-height: 60vh;
  display: flex;
  align-items: center;
  padding: 80px 0;
}
.page-404__inner {
  max-width: 720px;
  margin: 0 auto;
  text-align: center;
}
.page-404__code {
  font-family: var(--font-ui);
  font-size: clamp(96px, 16vw, 200px);
  font-weight: 600;
  line-height: 1;
  letter-spacing: -.04em;
  color: transparent;
  background: var(--grad);
  -webkit-background-clip: text;
          background-clip: text;
  margin-bottom: 24px;
}
.page-404__title {
  font-size: clamp(22px, 3vw, 32px);
  font-weight: 600;
  color: var(--ink);
  margin: 0 0 16px;
}
.page-404__lead {
  color: var(--ink-3);
  font-size: 15px;
  line-height: 1.95;
  margin: 0 0 36px;
}
.page-404__ctas {
  display: flex;
  justify-content: center;
  gap: 12px;
  flex-wrap: wrap;
}
