/* =====================================================================
   Coordinate Akita Cooperative ? Redesign v2
   "Cafe Editorial ・ Asymmetric"
   ===================================================================== */

:root {
  /* === Color === */
  --paper:        #f4f1ea;
  --paper-2:      #ebe6db;
  --paper-3:      #e2dccf;
  --cream:        #fbf8f1;
  --ink:          #4e4449;
  --ink-2:        #2a2620;
  --ink-3:        #56504a;
  --ink-4:        #8a8278;
  --rule:         rgba(22, 20, 15, 0.10);
  --rule-strong:  rgba(22, 20, 15, 0.22);
  --accent:       #b6552d;  /* 柿渋 */
  --accent-2:     #483d35;  /* hover ダーク */
  --accent-deep:  #8a3f1f;
  --accent-soft:  #eadcc8;
  --accent-hover: #ead6bc;
  --accent-hover-border: rgba(182, 85, 45, .58);
  --on-accent:    #f4f1ea;
  --shadow-soft:  0 1px 0 var(--rule), 0 30px 60px -36px rgba(22,20,15,.22);
  --shadow-lift:  0 40px 80px -40px rgba(40,30,20,.40);

  /* === Type === (original spec preserved) */
  --f-display:    'Noto Sans JP', system-ui, sans-serif;
  --f-display-en: 'Montserrat', sans-serif;
  --f-en:         'Montserrat', sans-serif;
  --f-body:       'Noto Sans JP', system-ui, sans-serif;
  --f-mono:       'JetBrains Mono', ui-monospace, 'SFMono-Regular', Menlo, monospace;

  /* === Layout === */
  --max:          1320px;
  --max-wide:     1480px;
  --pad-x:        clamp(20px, 4vw, 64px);
  --nav-h:        76px;
  --section-y:    clamp(96px, 11vw, 180px);
  --section-y-sm: clamp(64px, 7vw, 112px);
  --section-y-xs: clamp(32px, 4vw, 64px);
  --gutter:       clamp(20px, 2.4vw, 40px);

  /* === Motion === */
  --ease-out:  cubic-bezier(.6, 0, .2, 1);
  --ease-back: cubic-bezier(.2, .6, .2, 1);
  --t-fast:    .2s;
  --t-base:    .35s;
  --t-slow:    .55s;
}

/* === Reset === */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; overflow-x: hidden; }
body {
  font-family: var(--f-body);
  background: #E6E2DE;
  color: var(--ink);
  font-size: 16px;
  font-weight: 300;
  line-height: 1.75;
  font-feature-settings: "palt" 1;
  letter-spacing: 0.10em;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}
html.fonts-loading .nav-links,
html.fonts-loading .nav-right,
html.fonts-loading .hero-eyebrow,
html.fonts-loading .hero-v2-headline,
html.fonts-loading .hero-v2-actions,
html.fonts-loading .page-head-en,
html.fonts-loading .page-head-title,
html.fonts-loading .page-head-lead {
  opacity: 0 !important;
}
html.fonts-loaded .nav-links,
html.fonts-loaded .nav-right,
html.fonts-loaded .hero-eyebrow,
html.fonts-loaded .hero-v2-headline,
html.fonts-loaded .hero-v2-actions,
html.fonts-loaded .page-head-en,
html.fonts-loaded .page-head-title,
html.fonts-loaded .page-head-lead {
  opacity: 1;
}

.skip-link {
  position: fixed;
  left: 16px;
  top: 12px;
  z-index: 10000;
  transform: translateY(-160%);
  opacity: 0;
  pointer-events: none;
  padding: 10px 14px;
  border-radius: 4px;
  background: var(--ink);
  color: var(--paper);
  font-family: var(--f-display);
  font-size: 13px;
  font-weight: 500;
  letter-spacing: 0.04em;
  transition: transform .2s ease, opacity .2s ease;
}
.skip-link:focus {
  transform: translateY(-160%);
  outline: 0;
}
html.keyboard-nav .skip-link:focus {
  transform: translateY(0) !important;
  opacity: 1;
  pointer-events: auto;
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}
img, svg, video { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }

main a:not(.btn):not(.btn-primary):not(.btn-secondary):not(.btn-ghost):not(.pickup-card):not(.news-row):not(.system-row):not(.nav-cta),
.footer a,
.mobile-menu a {
  text-decoration-line: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 0.18em;
}

main a:not(.btn):not(.btn-primary):not(.btn-secondary):not(.btn-ghost):not(.pickup-card):not(.news-row):not(.system-row):not(.nav-cta):hover,
.footer a:hover,
.mobile-menu a:hover {
  text-decoration-thickness: 2px;
}

.page-head-crumb a,
.footer-brand-lockup,
.footer-bottom-links a,
.mobile-menu .nav-cta {
  text-decoration: none;
}
ul, ol { list-style: none; }
button, input, textarea, select {
  font: inherit; color: inherit; background: none; border: none; outline: none;
}
button { cursor: pointer; }
::selection { background: var(--accent); color: var(--on-accent); }
:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 3px;
  border-radius: 2px;
}

/* Decorative noise/paper texture */
body::before {
  content: "";
  position: fixed; inset: 0; z-index: 200; pointer-events: none;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='240' height='240' viewBox='0 0 240 240'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='1.8' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0.15  0 0 0 0 0.12  0 0 0 0 0.08  0 0 0 0.06 0'/></filter><rect width='240' height='240' filter='url(%23n)'/></svg>");
  opacity: 0.5;
  mix-blend-mode: multiply;
}

/* =====================================================================
   Type system
===================================================================== */
.eyebrow {
  display: inline-flex; align-items: center; gap: 12px;
  font-family: var(--f-display-en);
  font-size: 12px;
  font-weight: 300;
  line-height: 1;
  color: var(--ink-3);
  letter-spacing: 0.18em;
  text-transform: uppercase;
}
.eyebrow::before { content: ""; width: 28px; height: 1px; background: currentColor; }
.eyebrow-num {
  font-family: var(--f-display-en);
  font-size: 12px;
  font-weight: 300;
  color: var(--ink-4);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  display: inline-flex; align-items: center; gap: 12px;
}
.eyebrow-num::before { content: ""; width: 24px; height: 1px; background: currentColor; }

.jp-display, .serif-display {
  font-family: var(--f-display);
  font-weight: 300;
  color: var(--ink);
  text-wrap: balance;
  word-break: keep-all;
  overflow-wrap: anywhere;
  letter-spacing: 0.10em;
}

.display-xl { font-size: clamp(34px, 6.4vw, 82px); line-height: 1.1;  letter-spacing: 0.10em; }
.display-lg { font-size: clamp(24px, 4vw, 46px);   line-height: 1.18; letter-spacing: 0.10em; }
.display-md { font-size: clamp(18px, 2.8vw, 32px); line-height: 1.25; letter-spacing: 0.10em; }
.display-sm { font-size: clamp(14px, 2vw, 20px);   line-height: 1.4;  letter-spacing: 0.10em; }

.lead {
  font-size: 17px; line-height: 1.85; color: var(--ink-2);
  text-wrap: pretty;
  max-width: 56ch;
}
.body { font-size: 15px; line-height: 1.85; color: var(--ink-2); text-wrap: pretty; }
.caption { font-size: 13px; color: var(--ink-3); letter-spacing: 0.02em; }

/* Big numeric */
.num-xxl {
  font-family: var(--f-display-en);
  font-weight: 300;
  font-size: clamp(56px, 8vw, 120px);
  line-height: 1;
  color: var(--ink);
  letter-spacing: -0.03em;
  font-feature-settings: "lnum" 1;
}


/* Hand-mark accents */
.mark {
  display: inline-block; position: relative;
}
.mark::after {
  content: "";
  position: absolute; left: -6px; right: -6px; bottom: -2px; height: 0.45em;
  background: var(--accent);
  opacity: 0.20;
  z-index: -1;
  border-radius: 2px;
}

/* =====================================================================
   Layout primitives
===================================================================== */
.container       { max-width: var(--max);      margin: 0 auto; padding: 0 var(--pad-x); }
.container-wide  { max-width: var(--max-wide); margin: 0 auto; padding: 0 var(--pad-x); }
.container-fluid { width: 100%; padding: 0 var(--pad-x); }
.section         { padding: var(--section-y) 0; position: relative; }
.section-sm      { padding: var(--section-y-sm) 0; position: relative; }
.hairline        { border-top: 1px solid var(--rule); }
.grid-12         { display: grid; grid-template-columns: repeat(12, 1fr); gap: var(--gutter); }

/* =====================================================================
   Navigation
===================================================================== */
.nav {
  position: fixed; top: 0; left: 0; right: 0; z-index: 100;
  height: var(--nav-h);
  padding: 0 var(--pad-x);
  display: flex; align-items: center; justify-content: space-between;
  background: rgba(230, 226, 222, 0.82);
  backdrop-filter: saturate(180%) blur(16px);
  -webkit-backdrop-filter: saturate(180%) blur(16px);
  border-bottom: 1px solid transparent;
  transition: border-color .35s ease, background .35s ease;
}
html.nav-preload .hamburger span,
html.nav-preload .mobile-menu {
  transition: none !important;
}
.nav.scrolled {
  border-bottom-color: var(--rule);
  background: rgba(230, 226, 222, 0.94);
}
.nav-brand { display: flex; align-items: center; min-width: 0; flex: 0 0 auto; }
.nav-brand-lockup {
  width: 320px;
  height: 52px;
  object-fit: contain;
  object-position: left center;
  flex: 0 0 auto;
}
.nav-brand-mark { width: 64px; height: 64px; object-fit: contain; }
.nav-brand-text {
  display: flex; flex-direction: column; line-height: 1.1; gap: 9px;
  width: 252px; flex: 0 0 252px; min-width: 0; overflow: hidden;
}
.nav-brand-name {
  font-family: var(--f-display); font-size: 17px; font-weight: 500;
  color: var(--ink); letter-spacing: 0.02em;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.nav-brand-en {
  font-family: var(--f-display-en); font-size: 10.5px; font-weight: 300;
  color: var(--ink-3); letter-spacing: 0.18em; text-transform: uppercase;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.nav-links { display: flex; align-items: center; gap: 28px; flex: 0 0 auto; }
.nav-link {
  position: relative;
  font-size: 13.5px;
  font-weight: 500;
  color: var(--ink-2);
  letter-spacing: 0.02em;
  padding: 6px 0;
  transition: color .25s ease;
  white-space: nowrap;
}
.nav-link::after {
  content: ""; position: absolute; left: 0; right: 100%; bottom: 4px;
  height: 1px; background: var(--accent);
  transition: right .35s cubic-bezier(.6,0,.2,1);
}
.nav-link:hover { color: var(--accent); }
.nav-link:hover::after, .nav-link.active::after { right: 0; }
.nav-link.active { color: var(--ink); }
.nav-link small {
  display: block; font-family: var(--f-display-en); font-size: 10px;
  color: var(--ink-4); letter-spacing: 0.18em; font-weight: 300; margin-top: 2px;
  text-transform: uppercase;
}

.nav-right { display: flex; align-items: center; gap: 18px; margin-left: 18px; flex: 0 0 auto; }
.nav-disclaimer {
  flex: 1;
  font-size: 11px;
  color: var(--ink-3);
  text-align: center;
  padding: 0 24px;
  line-height: 1.5;
  letter-spacing: 0.02em;
}
.lang {
  display: inline-flex; align-items: center; justify-content: center; gap: 2px;
  min-width: 150px;
  background: rgba(22,20,15,.04); border-radius: 999px; padding: 4px;
}
.lang-btn {
  width: 34px;
  font-family: var(--f-en); font-size: 11px; font-weight: 500; letter-spacing: 0.12em;
  padding: 6px 10px; color: var(--ink-3); border-radius: 999px;
  text-align: center;
  transition: background .25s, color .25s;
}
.lang-btn.active { background: var(--ink); color: var(--paper); }
.lang-btn:hover:not(.active) { color: var(--ink); }
.nav-cta {
  display: inline-flex; align-items: center; gap: 10px;
  justify-content: center;
  min-width: 142px;
  font-size: 12.5px; font-weight: 500; letter-spacing: 0.06em;
  padding: 10px 18px; border-radius: 999px;
  background: var(--ink); color: var(--paper);
  white-space: nowrap;
  transition: background .25s, transform .35s cubic-bezier(.6,0,.2,1);
}
.nav-cta::after { content: "→"; transition: transform .35s; }
.nav-cta:hover { background: var(--accent); transform: translateY(-1px); }
.nav-cta:hover::after { transform: translateX(3px); }

.hamburger {
  display: none;
  visibility: hidden;
  flex-direction: column;
  gap: 5px;
  justify-content: center;
  align-items: center;
  padding: 0;
  border: 0;
  background: transparent;
  color: var(--ink);
  cursor: pointer;
  flex-shrink: 0;
}

.hamburger span {
  display: block;
  width: 22px;
  height: 1.5px;
  background: var(--ink);
}

/* Side rail ? vertical scroll progress */
.side-rail {
  position: fixed; top: 0; bottom: 0; left: max(16px, 1vw); z-index: 90;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  pointer-events: none;
}
.side-rail-track {
  width: 1px; flex: 1; max-height: 50vh;
  background: linear-gradient(to bottom, transparent, var(--rule-strong) 14%, var(--rule-strong) 86%, transparent);
}
.side-rail-mark {
  writing-mode: vertical-rl;
  font-family: var(--f-en); font-size: 10.5px; letter-spacing: 0.4em;
  color: var(--ink-3); text-transform: uppercase;
  padding: 18px 0;
}
@media (max-width: 1100px) { .side-rail { display: none; } }

/* Mobile nav */
@media (max-width: 1100px) {
  .nav-links, .nav-right { display: none; }
  .nav-brand {
    max-width: calc(100% - 52px);
  }
  .hamburger {
    display: flex;
    visibility: visible;
    width: 36px;
    height: 36px;
    margin-left: auto;
  }
  .hamburger span { width: 22px; height: 1.5px; background: var(--ink); display: block; transition: transform .35s; }
}
.mobile-menu {
  position: fixed; inset: var(--nav-h) 0 0 0; z-index: 99;
  background: var(--paper); padding: 32px var(--pad-x);
  transform: translateY(-110%); transition: transform .5s cubic-bezier(.6,0,.2,1);
  display: flex; visibility: hidden; flex-direction: column; gap: 20px;
  overflow-y: auto;
}
.mobile-menu.open { visibility: visible; transform: translateY(0); }
.mobile-menu a {
  display: flex; justify-content: space-between; align-items: baseline;
  padding: 14px 0; border-bottom: 1px solid var(--rule);
  font-family: var(--f-display); font-size: 17px; font-weight: 500; color: var(--ink); letter-spacing: 0.04em;
}
.mobile-menu a small {
  font-family: var(--f-display-en); font-size: 11px; font-weight: 300;
  color: var(--ink-4); letter-spacing: 0.18em; text-transform: uppercase;
}
.mobile-menu .nav-cta {
  color: var(--paper); border-bottom: none;
  display: inline-flex; width: auto; justify-content: center;
  padding: 14px 28px; margin-top: 4px;
}

/* =====================================================================
   Hero ? Asymmetric editorial
===================================================================== */
.hero {
  padding: calc(var(--nav-h) + 64px) 0 64px;
  position: relative;
  overflow: hidden;
  background: transparent;
}
.hero .container-wide { display: flex; flex-direction: column; }

.hero-title-display {
  font-size: clamp(28px, 5vw, 56px);
  line-height: 1.4;
  margin-bottom: clamp(48px, 5vw, 72px);
  max-width: none;
  white-space: nowrap;
}
@media (max-width: 700px) {
  .hero-title-display { white-space: normal; font-size: clamp(26px, 6.5vw, 36px); }
}

.hero-meta-row {
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(280px, 0.95fr);
  gap: clamp(36px, 5vw, 96px);
  align-items: start;
  padding-top: clamp(28px, 3.5vw, 48px);
  border-top: 1px solid var(--rule);
}
@media (max-width: 800px) { .hero-meta-row { grid-template-columns: 1fr; } }


.hero-grid {
  display: grid;
  grid-template-columns: minmax(0,1fr) minmax(280px, 0.7fr);
  gap: clamp(24px, 4vw, 80px);
  align-items: end;
  position: relative;
}
.hero-headline {
  position: relative;
}
.hero-eyebrow {
  display: inline-flex; align-items: center; gap: 12px;
  font-family: var(--f-display-en); font-size: 12px; font-weight: 300;
  color: var(--ink-3); letter-spacing: 0.18em; text-transform: uppercase;
  margin-bottom: 28px;
}
.hero-eyebrow::before { content: ""; width: 28px; height: 1px; background: currentColor; }
.hero-title {
  font-family: var(--f-display);
  font-weight: 300;
  font-size: clamp(26px, 3.6vw, 48px);
  line-height: 1.25;
  letter-spacing: 0.10em;
  color: var(--ink);
  text-wrap: balance;
  word-break: keep-all;
  overflow-wrap: anywhere;
}
.hero-title em {
  font-style: normal;
  background: linear-gradient(to top, var(--accent-soft) 32%, transparent 32%);
  padding: 0 0.08em;
}

.hero-side {
  display: flex; flex-direction: column; gap: 28px;
  padding-bottom: clamp(16px, 3vw, 48px);
}
.hero-image {
  position: relative;
  aspect-ratio: 4/5;
  overflow: hidden;
  background: var(--paper-3);
  border-radius: 2px;
  transform: translateY(0);
}
.hero-image img {
  width: 100%; height: 100%;
  object-fit: cover;
  transform: scale(1.05);
  will-change: transform;
}
.hero-image-caption {
  position: absolute; bottom: 14px; right: 14px;
  background: rgba(244,241,234,.92);
  padding: 8px 14px;
  font-family: var(--f-display-en); font-size: 11px; font-weight: 300;
  color: var(--ink-3);
  letter-spacing: 0.18em; text-transform: uppercase;
  border-radius: 2px;
}

.hero-body {
  font-size: 15px;
  color: var(--ink-2);
  max-width: 48ch;
  line-height: 1.95;
  font-weight: 300;
  letter-spacing: 0.08em;
}

.hero-meta {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 18px 32px;
}
.hero-meta-item {
  display: flex; flex-direction: column; gap: 4px;
}
.hero-meta-key {
  font-family: var(--f-display-en); font-size: 10.5px; font-weight: 300; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--ink-4);
}
.hero-meta-val {
  font-family: var(--f-display); font-size: 14px; color: var(--ink); font-weight: 500; letter-spacing: 0.04em;
}

.hero-actions {
  display: flex; gap: 16px; flex-wrap: wrap;
  margin-top: clamp(40px, 5vw, 64px);
}


/* Hero corner numerals */
.hero-corner {
  position: absolute; right: var(--pad-x); top: calc(var(--nav-h) + 20px);
  font-family: var(--f-display-en); font-size: 11px; font-weight: 300; letter-spacing: 0.18em; color: var(--ink-3);
  text-transform: uppercase;
  display: flex; align-items: center; gap: 10px;
}
.hero-corner::before { content: ""; width: 32px; height: 1px; background: var(--ink-3); }

/* =====================================================================
   Buttons (original spec)
===================================================================== */
.btn {
  display: inline-flex; align-items: center; gap: 12px;
  padding: 16px 26px;
  font-family: var(--f-body);
  font-size: 14px;
  font-weight: 500;
  letter-spacing: 0.02em;
  border-radius: 999px;
  transition: all .25s;
  cursor: pointer;
}
.btn-primary {
  background: var(--ink); color: var(--paper);
  border: 1px solid var(--ink);
}
.btn-primary:hover { background: var(--accent-2); border-color: var(--accent-2); transform: translateY(-1px); }
.btn-secondary {
  background: transparent; color: var(--ink);
  border: 1px solid var(--ink);
}
.btn-secondary:hover { background: var(--ink); color: var(--paper); }
.btn-ghost {
  padding: 12px 0;
  color: var(--ink);
  border-bottom: 1px solid var(--ink);
  border-radius: 0;
  gap: 14px;
}
.btn-ghost:hover { color: var(--accent-2); border-bottom-color: var(--accent-2); gap: 20px; }

.btn .arrow {
  width: 20px; height: 1px; background: currentColor; position: relative;
  transition: width .25s;
}
.btn .arrow::before { display: none; }
.btn .arrow::after {
  content: ""; position: absolute; right: 0; top: -3px;
  width: 7px; height: 7px;
  background: transparent;
  border-top: 1px solid currentColor;
  border-right: 1px solid currentColor;
  transform: rotate(45deg);
  height: 7px;
}
.btn:hover .arrow { width: 28px; animation: none; }

/* =====================================================================
   Section heads ? asymmetric
===================================================================== */
.sec-head {
  display: grid;
  grid-template-columns: minmax(0, 1.5fr) minmax(0, 1fr);
  gap: clamp(40px, 5vw, 80px);
  align-items: start;
  margin-bottom: clamp(48px, 6vw, 96px);
}
.sec-head-num {
  font-family: var(--f-display-en); font-size: 12px; font-weight: 300; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--ink-3);
  display: inline-flex; align-items: center; gap: 14px;
  margin-bottom: 20px;
}
.sec-head-num::before { content: ""; width: 28px; height: 1px; background: var(--ink-3); }
.sec-head h2 {
  font-family: var(--f-display);
  font-size: clamp(20px, 2.8vw, 34px);
  font-weight: 300;
  color: var(--ink);
  line-height: 1.55;
  letter-spacing: 0.10em;
  white-space: nowrap;
  word-break: keep-all;
  overflow-wrap: normal;
}
.sec-head h2 em {
  font-style: normal;
  background: linear-gradient(to top, var(--accent-soft) 32%, transparent 32%);
  padding: 0 0.08em;
}
.sec-head-body {
  font-size: 15px; color: var(--ink-2); line-height: 1.85;
  max-width: 48ch;
  padding-top: 36px;
}
.sec-head--center {
  grid-template-columns: 1fr;
  text-align: center;
  justify-items: center;
}
.sec-head--center .sec-head-body { margin: 0 auto; }

/* Offset section head ? heading lifted left of column */
.sec-head--offset {
  grid-template-columns: minmax(0, 0.4fr) minmax(0, 1.6fr);
}

/* =====================================================================
   Manifesto / quote
===================================================================== */
.manifesto {
  display: grid;
  grid-template-columns: minmax(0, 1.5fr) minmax(0, 1fr);
  gap: clamp(40px, 5vw, 80px);
  align-items: start;
  padding: clamp(48px, 6vw, 96px) 0;
}
.manifesto-quote {
  font-family: var(--f-display);
  font-weight: 300;
  font-size: clamp(20px, 2.8vw, 34px);
  line-height: 1.55;
  color: var(--ink);
  letter-spacing: 0.10em;
  white-space: nowrap;
  word-break: keep-all;
  overflow-wrap: normal;
}
.manifesto-quote em {
  font-style: normal;
  background: linear-gradient(to top, var(--accent-soft) 32%, transparent 32%);
  padding: 0 0.08em;
}
.manifesto-quote .jp {
  display: block;
  margin-top: 28px;
  font-family: var(--f-display-en); font-style: normal;
  font-size: 12px; font-weight: 300;
  color: var(--ink-3);
  letter-spacing: 0.18em; text-transform: uppercase;
  line-height: 1.6;
}
.manifesto-body {
  display: flex; flex-direction: column; gap: 20px;
}
.manifesto-body p { font-size: 15px; line-height: 1.85; color: var(--ink-2); }
.manifesto-meta {
  display: grid; grid-template-columns: 1fr 1fr; gap: 14px 28px;
  margin-top: 24px; padding-top: 24px; border-top: 1px solid var(--rule);
}
.manifesto-meta-item dt {
  font-family: var(--f-display-en); font-size: 10.5px; font-weight: 300; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--ink-4); margin-bottom: 4px;
}
.manifesto-meta-item dd { font-size: 14px; color: var(--ink); font-weight: 500; letter-spacing: 0.04em; }

@media (max-width: 800px) {
  .manifesto, .sec-head, .sec-head--offset, .hero-grid { grid-template-columns: 1fr; }
  .sec-head h2, .manifesto-quote, .page-head-title, .quote-bar blockquote, .cta-block h2 {
    white-space: normal;
  }
  .sec-head-body { padding-top: 0; }
}

/* =====================================================================
   Pillar cards (3-up)
===================================================================== */
.pillars {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: var(--rule);
  border-top: 1px solid var(--rule);
  border-bottom: 1px solid var(--rule);
}
.pillar {
  background: var(--paper);
  padding: clamp(28px, 3.2vw, 52px) clamp(20px, 2.4vw, 36px);
  display: flex; flex-direction: column; gap: 22px;
  position: relative;
  min-height: 240px;
  transition: background .35s;
}
.pillar::before {
  content: ""; position: absolute; left: 0; top: 0; height: 100%;
  width: 0; background: var(--accent); transition: width .45s cubic-bezier(.6,0,.2,1);
}
.pillar:hover {
  background: var(--accent-hover);
}
.pillar:hover::before { width: 3px; }
.pillar-num {
  font-family: var(--f-display-en); font-size: 12px; font-weight: 300;
  color: var(--ink-4); letter-spacing: 0.18em; text-transform: uppercase;
  display: inline-flex; align-items: baseline; gap: 14px;
  transition: color .35s;
}
.pillar-num::after { content: ""; height: 1px; flex: 1; background: var(--rule); margin-top: 6px; transition: background .35s; }
.pillar h3 {
  font-family: var(--f-display); font-size: clamp(18px, 2.8vw, 24px);
  font-weight: 500; color: var(--ink); letter-spacing: 0.10em; line-height: 1.45;
  margin-bottom: 2px;
  transition: color .35s;
}
.pillar p { font-size: 14px; line-height: 1.9; color: var(--ink-2); margin-top: 0; }
.pillar:hover .pillar-num { color: var(--accent-deep); }
.pillar:hover .pillar-num::after { background: var(--accent); }
.pillar:hover h3 { color: var(--accent-deep); }

/* 3n+1 番目かつ最後のカードが単独で行に残る場合は全幅にスパン・横並びに */
.pillars .pillar:nth-child(3n + 1):last-child {
  grid-column: 1 / -1;
  flex-direction: row;
  align-items: center;
  gap: clamp(32px, 5vw, 80px);
}
.pillars .pillar:nth-child(3n + 1):last-child .pillar-num {
  flex-shrink: 0;
}
.pillars .pillar:nth-child(3n + 1):last-child h3 {
  flex-shrink: 0;
}
.pillars .pillar:nth-child(3n + 1):last-child p {
  max-width: 40ch;
  margin-top: 0;
}

@media (max-width: 800px) {
  .pillars { grid-template-columns: 1fr; }
  .pillars .pillar:nth-child(3n + 1):last-child {
    flex-direction: column;
    align-items: stretch;
  }
}

.duration-note {
  margin: clamp(32px, 4vw, 56px) 0 18px;
  font-size: 13.5px;
  line-height: 1.8;
  color: var(--ink-3);
  letter-spacing: 0.06em;
}


/* =====================================================================
   Systems list ? staggered rows
===================================================================== */
.systems-list {
  display: flex; flex-direction: column;
  border-top: 1px solid var(--rule);
}
.system-row {
  display: grid;
  grid-template-columns: 80px minmax(0, 0.9fr) minmax(0, 1.4fr) 60px;
  gap: clamp(16px, 2vw, 40px);
  padding: clamp(28px, 3vw, 44px) 20px;
  margin-left: -20px; margin-right: -20px;
  border-bottom: 1px solid var(--rule);
  align-items: start;
  position: relative;
  border-radius: 6px;
  transition: background .35s ease;
}
.system-row::before {
  content: ""; position: absolute; left: 0; top: 0; height: 100%;
  width: 0; background: var(--accent); transition: width .45s cubic-bezier(.6,0,.2,1);
}
.system-row:hover {
  background: var(--accent-hover);
}
.system-row:hover::before { width: 3px; }
.system-row-num {
  font-family: var(--f-display-en); font-size: clamp(20px, 2vw, 28px);
  color: var(--ink-4); font-weight: 300; letter-spacing: 0.04em;
  line-height: 1;
  transition: color .35s, transform .35s;
}
.system-row-title {
  font-family: var(--f-display); font-size: clamp(18px, 2.8vw, 26px);
  font-weight: 500; color: var(--ink); letter-spacing: 0.10em; line-height: 1.35;
  display: flex; flex-direction: column; gap: 10px;
  transition: color .35s;
}
.system-row-title small {
  font-family: var(--f-display-en); font-size: 11px; font-weight: 300;
  color: var(--ink-4); letter-spacing: 0.18em; text-transform: uppercase;
}
.system-row-body { font-size: 14.5px; color: var(--ink-2); line-height: 1.9; letter-spacing: 0.08em; padding-top: 2px; }
.system-row-arrow {
  align-self: center; justify-self: end;
  width: 44px; height: 44px; border-radius: 50%;
  border: 1px solid var(--rule-strong); display: inline-flex; align-items: center; justify-content: center;
  transition: background .35s, color .35s, transform .35s;
  position: relative;
}
.system-row-arrow::after {
  content: ""; width: 16px; height: 1px; background: currentColor; position: relative;
}
.system-row-arrow::before {
  content: ""; width: 8px; height: 8px; border-top: 1px solid currentColor; border-right: 1px solid currentColor;
  transform: rotate(45deg); position: absolute; right: 13px;
}
.system-row:hover .system-row-arrow {
  background: var(--accent); color: var(--paper); border-color: var(--accent);
  transform: rotate(-12deg) translateX(4px);
}
.system-row:hover .system-row-num {
  color: var(--accent-deep);
  transform: translateX(2px);
}
.system-row:hover .system-row-title {
  color: var(--accent-deep);
}

@media (max-width: 800px) {
  .system-row { grid-template-columns: 60px 1fr; }
  .system-row-body, .system-row-arrow { grid-column: 1 / -1; }
  .system-row-arrow { justify-self: start; margin-top: 8px; }
}

/* =====================================================================
   Process timeline (vertical)
===================================================================== */
.process-grid {
  display: grid;
  grid-template-columns: minmax(0, 0.9fr) minmax(0, 1.4fr);
  gap: clamp(40px, 6vw, 100px);
  align-items: start;
}
.process-grid-left h2 { margin: 18px 0 24px; }
.process-timeline {
  position: relative;
}
.process-timeline::before {
  content: ""; position: absolute; left: 24px; top: 18px; bottom: 18px;
  width: 1px; background: var(--rule-strong);
}
.process-step {
  display: grid;
  grid-template-columns: 60px 1fr;
  gap: 28px;
  padding: clamp(22px, 2.4vw, 36px) 20px;
  margin-left: -20px; margin-right: -20px;
  align-items: start;
  position: relative;
  border-radius: 6px;
  transition: background .35s;
}
.process-step + .process-step { border-top: 1px solid var(--rule); }
.process-step::before {
  content: ""; position: absolute; left: 0; top: 0; height: 100%;
  width: 0; background: var(--accent); transition: width .45s cubic-bezier(.6,0,.2,1);
}
.process-step:hover {
  background: var(--accent-hover);
}
.process-step:hover::before { width: 3px; }
.process-step-num {
  width: 48px; height: 48px; border-radius: 50%;
  background: var(--paper); border: 1px solid var(--rule-strong);
  font-family: var(--f-display-en); font-size: 13px; font-weight: 300;
  color: var(--ink-3); letter-spacing: 0.08em;
  display: inline-flex; align-items: center; justify-content: center;
  position: relative; z-index: 2;
  transition: background .35s, color .35s, border-color .35s, transform .35s;
}
.process-step:hover .process-step-num {
  background: var(--accent); color: var(--paper); border-color: var(--accent); transform: scale(1.06);
}
.process-step h3 {
  font-family: var(--f-display); font-size: clamp(17px, 2.2vw, 21px);
  font-weight: 500; color: var(--ink); letter-spacing: 0.10em; margin-bottom: 8px;
  transition: color .35s;
}
.process-step:hover h3 { color: var(--accent-deep); }
.process-step p { font-size: 14px; line-height: 1.85; color: var(--ink-2); max-width: 52ch; letter-spacing: 0.08em; }
.history-timeline .process-step p {
  white-space: nowrap;
  max-width: none;
}

@media (max-width: 800px) { .process-grid { grid-template-columns: 1fr; } }

/* =====================================================================
   Quote bar
===================================================================== */
.quote-bar {
  background: var(--ink);
  color: var(--paper);
  padding: clamp(80px, 9vw, 140px) 0;
  position: relative;
  overflow: hidden;
}
.quote-bar::before {
  content: "“";
  position: absolute; left: var(--pad-x); top: -60px;
  font-family: Georgia, serif; font-size: 360px;
  color: rgba(244,241,234,.06); line-height: 1;
  pointer-events: none;
}
.quote-bar blockquote {
  font-family: var(--f-display); font-weight: 300;
  font-size: clamp(20px, 2.8vw, 34px); line-height: 1.55;
  color: var(--paper);
  max-width: none;
  letter-spacing: 0.10em;
  white-space: nowrap;
  word-break: keep-all;
  overflow-wrap: normal;
}
.quote-bar blockquote em {
  font-style: normal;
  background: linear-gradient(to top, rgba(182,85,45,.45) 32%, transparent 32%);
  padding: 0 0.08em;
}
.quote-bar .jp {
  display: block; margin-top: 20px;
  font-family: var(--f-display-en); font-style: normal;
  font-size: 12px; color: rgba(244,241,234, .7); font-weight: 300;
  letter-spacing: 0.18em; line-height: 1.6; text-transform: uppercase;
}
.quote-bar cite {
  display: block; margin-top: 36px;
  font-family: var(--f-display-en); font-style: normal; font-size: 11px; font-weight: 300;
  letter-spacing: 0.18em; text-transform: uppercase;
  color: rgba(244,241,234,.6);
}
.quote-bar cite::before { content: "? "; }

/* =====================================================================
   News
===================================================================== */
.news-list { display: flex; flex-direction: column; }
.news-row {
  display: grid;
  grid-template-columns: 120px 120px 1fr 60px;
  gap: 28px;
  padding: 24px 0;
  border-top: 1px solid var(--rule);
  align-items: center;
  transition: padding .35s ease;
  position: relative;
}
.news-row:last-child { border-bottom: 1px solid var(--rule); }
.news-row::before {
  content: ""; position: absolute; left: 0; right: 100%; top: 0; bottom: 0;
  background: var(--accent-hover); z-index: -1; transition: right .45s cubic-bezier(.6,0,.2,1);
}
.news-row::after {
  content: ""; position: absolute; left: 0; top: 0; height: 100%;
  width: 0; background: var(--accent); transition: width .45s cubic-bezier(.6,0,.2,1);
}
.news-row:hover { padding-left: 16px; padding-right: 16px; }
.news-row:hover::before { right: 0; }
.news-row:hover::after { width: 3px; }
.news-row:hover .news-row-title { color: var(--accent-deep); }
.news-row-date {
  font-family: var(--f-display-en); font-size: 12.5px; font-weight: 300; color: var(--ink-3); letter-spacing: 0.08em;
}
.news-row-cat {
  font-size: 11px; letter-spacing: 0.18em;
  color: var(--accent);
  border: 1px solid currentColor; padding: 4px 10px; border-radius: 999px;
  justify-self: start;
  font-family: var(--f-display); font-weight: 500;
}
.news-row-title {
  font-family: var(--f-display); font-size: 15.5px; color: var(--ink); font-weight: 500; letter-spacing: 0.06em;
  transition: color .35s;
}
.news-row-arrow {
  width: 36px; height: 36px; border-radius: 50%;
  border: 1px solid var(--rule-strong);
  display: inline-flex; align-items: center; justify-content: center; justify-self: end;
  transition: background .35s, color .35s, border-color .35s, transform .35s;
}
.news-row-arrow::after { content: "→"; font-size: 14px; color: var(--ink); }
.news-row:hover .news-row-arrow { background: var(--accent); border-color: var(--accent); transform: rotate(-45deg); }
.news-row:hover .news-row-arrow::after { color: var(--paper); }

@media (max-width: 800px) {
  .news-row { grid-template-columns: 1fr; gap: 8px; padding: 20px 0; }
  .news-row-arrow { display: none; }
}

/* =====================================================================
   CTA Block
===================================================================== */
.cta-block {
  background: var(--ink);
  color: var(--paper);
  padding: clamp(48px, 6vw, 96px) clamp(32px, 4vw, 72px);
  border-radius: 4px;
  display: grid;
  grid-template-columns: minmax(0, 1.3fr) auto;
  gap: clamp(32px, 4vw, 64px);
  align-items: center;
  position: relative;
  overflow: hidden;
}
.cta-block::before {
  content: "";
  position: absolute; right: -80px; bottom: -100px;
  width: 360px; height: 360px;
  background: radial-gradient(circle at 30% 30%, rgba(182,85,45,.55), transparent 60%);
  filter: blur(20px);
  pointer-events: none;
}
.cta-block-eyebrow {
  font-family: var(--f-display-en); font-size: 12px; font-weight: 300; letter-spacing: 0.18em; text-transform: uppercase;
  color: rgba(244,241,234,.65); margin-bottom: 16px;
}
.cta-block h2 {
  font-family: var(--f-display); font-size: clamp(20px, 2.4vw, 30px);
  font-weight: 300; color: var(--paper); line-height: 1.55; letter-spacing: 0.10em;
  max-width: none;
  word-break: keep-all;
}
.cta-block h2 > span {
  display: inline-block;
  white-space: nowrap;
  word-break: keep-all;
}
.cta-block h2 em {
  font-style: normal;
  background: linear-gradient(to top, rgba(182,85,45,.45) 30%, transparent 30%);
  padding: 0 0.08em;
}
.cta-block-actions { display: flex; gap: 14px; flex-wrap: wrap; }
.cta-block .btn-primary { background: var(--accent); border-color: var(--accent); color: var(--paper); }
.cta-block .btn-primary:hover { background: var(--paper); border-color: var(--paper); color: var(--ink); }
.cta-block .btn-secondary { background: transparent; color: var(--paper); border: 1px solid rgba(244,241,234,.4); }
.cta-block .btn-secondary:hover { background: var(--paper); border-color: var(--paper); color: var(--ink); }

@media (max-width: 800px) { .cta-block { grid-template-columns: 1fr; } }

/* =====================================================================
   Page head
===================================================================== */
.page-head {
  padding: calc(var(--nav-h) + 96px) 0 clamp(84px, 9vw, 144px);
  position: relative;
}
.page-head-bg {
  position: absolute;
  inset: 0;
  z-index: 0;
  overflow: hidden;
  pointer-events: none;
  border-radius: 0;
}
.page-head-bg img {
  width: 100%; height: 100%;
  object-fit: cover;
  opacity: 0.34;
  filter: grayscale(0.15) sepia(0.12) saturate(1.08);
}
.page-head-bg picture {
  display: block;
  width: 100%;
  height: 100%;
}
.page-head-bg--wide img {
  width: 100vw;
  height: 100%;
  max-width: none;
  object-fit: cover;
  object-position: center 42%;
}
.page-head-bg--flow img {
  object-position: center 62%;
}
.page-head-bg--access img {
  object-position: center 72%;
}
.page-head-bg--qa img {
  object-position: center 50%;
}
.page-head-bg--contact img {
  object-position: center 18%;
}
.page-head > .container {
  position: relative;
  z-index: 1;
}
.page-head-crumb {
  display: flex; align-items: center; gap: 10px;
  font-family: var(--f-display-en); font-size: 11px; font-weight: 300; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--ink-4); margin-bottom: 36px;
}
.page-head-crumb a:hover { color: var(--accent); }
.page-head-inner {
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(0, 0.9fr);
  gap: clamp(40px, 6vw, 120px);
  align-items: end;
}
.page-head-en {
  font-family: var(--f-display-en); font-size: 12px; font-weight: 300;
  color: var(--ink-3); letter-spacing: 0.18em; text-transform: uppercase; display: block; margin-bottom: 14px;
}
.page-head-title {
  font-family: var(--f-display); font-size: clamp(22px, 3.5vw, 38px);
  font-weight: 300; color: var(--ink); letter-spacing: 0.10em; line-height: 1.2;
  white-space: nowrap;
  word-break: keep-all;
  overflow-wrap: normal;
}
.page-head-lead { font-size: 15.5px; line-height: 1.85; color: var(--ink-2); max-width: 46ch; letter-spacing: 0.08em; }

@media (max-width: 800px) { .page-head-inner { grid-template-columns: 1fr; } }

/* =====================================================================
   Info list
===================================================================== */
.info-list { display: flex; flex-direction: column; border-top: 1px solid var(--rule); }
.info-row {
  display: grid;
  grid-template-columns: minmax(140px, 220px) 1fr;
  gap: 32px;
  padding: 22px 0;
  border-bottom: 1px solid var(--rule);
  align-items: start;
}
.info-row .info-term {
  font-family: var(--f-display); font-size: 13px; font-weight: 500; letter-spacing: 0.18em;
  color: var(--ink-4);
}
.info-row .info-def { font-size: 15px; color: var(--ink); line-height: 1.85; letter-spacing: 0.06em; }
@media (max-width: 700px) {
  .info-row { grid-template-columns: 1fr; gap: 4px; }
}

/* =====================================================================
   Cards (Do / Don't)
===================================================================== */
.card-grid {
  display: grid; grid-template-columns: repeat(2, 1fr); gap: clamp(20px, 2.4vw, 40px);
}
.card {
  background: var(--cream);
  padding: clamp(28px, 3vw, 48px);
  border-radius: 4px;
  position: relative;
  border: 1px solid var(--rule);
  transition: background .35s, border-color .35s;
}
.card--paper {
  background: var(--paper);
}
.card::before {
  content: ""; position: absolute; left: 0; top: 0; height: 100%;
  width: 0; background: var(--accent); transition: width .45s cubic-bezier(.6,0,.2,1);
}
.card:hover {
  background: var(--accent-hover);
  border-color: var(--accent-hover-border);
}
.card:hover::before { width: 3px; }
.card-tag {
  display: inline-block;
  font-family: var(--f-display-en); font-size: 11px; font-weight: 300;
  color: var(--accent); letter-spacing: 0.18em; text-transform: uppercase;
  padding-bottom: 4px; border-bottom: 1px solid var(--accent);
  margin-bottom: 24px;
}
.card-tag--muted {
  color: var(--ink-4);
  border-color: var(--rule-strong);
}
.card:hover .card-tag {
  color: var(--accent);
  border-color: var(--accent);
}
.card h3 {
  font-family: var(--f-display); font-size: clamp(18px, 2.8vw, 24px);
  font-weight: 500; color: var(--ink); letter-spacing: 0.10em;
  margin-bottom: 16px;
  transition: color .35s;
}
.card:hover h3 { color: var(--accent-deep); }
.card p { font-size: 14.5px; line-height: 1.85; color: var(--ink-2); letter-spacing: 0.08em; }
@media (max-width: 700px) { .card-grid { grid-template-columns: 1fr; } }

/* =====================================================================
   Job cells (Systems page ? specified skilled work fields)
===================================================================== */
.job-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: 1px;
  background: var(--rule);
  border: 1px solid var(--rule);
}
.job-cell {
  background: var(--paper);
  padding: 18px 16px;
  display: flex; flex-direction: column; gap: 8px;
  position: relative;
  transition: background .25s;
}
.job-cell::before {
  content: ""; position: absolute; left: 0; top: 0; height: 100%;
  width: 0; background: var(--accent); transition: width .35s cubic-bezier(.6,0,.2,1);
}
.job-cell:hover {
  background: var(--accent-hover);
}
.job-cell:hover::before { width: 3px; }
.job-cell-num {
  font-family: var(--f-display-en); font-size: 10.5px; font-weight: 300; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--ink-4);
  transition: color .25s;
}
.job-cell:hover .job-cell-num { color: var(--accent); }
.job-cell strong {
  font-family: var(--f-display); font-size: 14.5px; font-weight: 500; color: var(--ink);
  letter-spacing: 0.08em;
  transition: color .25s;
}
.job-cell:hover strong { color: var(--accent-deep); }
.job-cell span {
  font-family: var(--f-display-en); font-size: 10.5px; font-weight: 300; color: var(--ink-4);
  letter-spacing: 0.16em; text-transform: uppercase;
}

/* =====================================================================
   FAQ
===================================================================== */
.faq { display: flex; flex-direction: column; border-top: 1px solid var(--rule); }
.faq-item { border-bottom: 1px solid var(--rule); }
.faq-q {
  width: 100%;
  display: grid;
  grid-template-columns: 60px 1fr 36px;
  gap: 24px;
  align-items: center;
  padding: 22px 0;
  text-align: left;
  transition: padding .35s;
}
.faq-q:hover { padding-left: 12px; padding-right: 12px; }
.faq-q-num {
  font-family: var(--f-display-en); font-size: 14px; font-weight: 300;
  color: var(--ink-4); letter-spacing: 0.10em;
}
.faq-q-text {
  font-family: var(--f-display); font-size: 16px; font-weight: 500;
  color: var(--ink); letter-spacing: 0.06em; line-height: 1.5;
}
.faq-q-toggle {
  position: relative; width: 22px; height: 22px;
  transition: transform .45s cubic-bezier(.6,0,.2,1);
  justify-self: end;
}
.faq-q-toggle::before, .faq-q-toggle::after {
  content: ""; position: absolute; left: 50%; top: 50%;
  width: 18px; height: 1px; background: var(--ink-2);
  transform-origin: center;
  transition: transform .45s cubic-bezier(.6,0,.2,1);
}
.faq-q-toggle::before { transform: translate(-50%,-50%); }
.faq-q-toggle::after  { transform: translate(-50%,-50%) rotate(90deg); }
.faq-item.open .faq-q-toggle { transform: rotate(180deg); }
.faq-item.open .faq-q-toggle::after { transform: translate(-50%,-50%) rotate(0deg); }
.faq-a {
  max-height: 0; overflow: hidden;
  transition: max-height .55s cubic-bezier(.6,0,.2,1);
}
.faq-item.open .faq-a { max-height: 600px; }
.faq-a-text {
  padding: 0 0 24px 84px;
  font-size: 14.5px; line-height: 1.95; color: var(--ink-2);
  max-width: 68ch;
}
@media (max-width: 700px) {
  .faq-q { grid-template-columns: 40px 1fr 30px; gap: 14px; }
  .faq-a-text { padding-left: 54px; }
}

.related-links-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  align-items: stretch;
  gap: 1px;
  background: var(--rule);
  border-top: 1px solid var(--rule);
  border-bottom: 1px solid var(--rule);
}
.related-link-card {
  background: var(--paper);
  padding: clamp(24px, 2.8vw, 40px);
  min-height: 390px;
  height: 100%;
  display: flex;
  flex-direction: column;
  gap: 16px;
  position: relative;
  transition: background .35s;
}
.related-link-card::before {
  content: ""; position: absolute; left: 0; top: 0; height: 100%;
  width: 0; background: var(--accent); transition: width .45s cubic-bezier(.6,0,.2,1);
}
.related-link-card:hover {
  background: var(--accent-hover);
}
.related-link-card:hover::before { width: 3px; }
.related-link-num {
  font-family: var(--f-display-en);
  font-size: 12px;
  font-weight: 300;
  color: var(--ink-4);
  letter-spacing: 0.18em;
  transition: color .35s;
}
.related-link-card h3 {
  font-family: var(--f-display);
  font-size: clamp(16px, 2vw, 20px);
  font-weight: 500;
  line-height: 1.55;
  letter-spacing: 0.08em;
  color: var(--ink);
  transition: color .35s;
  min-height: 4.9em;
}
.related-link-card h3 span {
  display: block;
  font-size: 0.86em;
  line-height: 1.55;
  margin-top: 2px;
}
.related-link-card p {
  font-size: 13.5px;
  line-height: 1.85;
  letter-spacing: 0.06em;
  color: var(--ink-2);
}
.related-link-use,
.related-link-dest {
  padding-top: 12px;
  border-top: 1px solid var(--rule);
}
.related-link-dest {
  color: var(--ink-3);
  font-size: 11.5px;
  line-height: 1.7;
}
.related-link-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: auto;
}
.related-link-badges {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: auto;
  padding-top: 12px;
  border-top: 1px solid var(--rule);
}
.related-link-badges span {
  display: inline-flex;
  align-items: center;
  min-height: 24px;
  padding: 5px 9px;
  border: 1px solid var(--accent);
  border-radius: 999px;
  color: var(--accent-deep);
  background: transparent;
  font-size: 11px;
  line-height: 1;
  letter-spacing: 0.08em;
}
.related-link-button {
  display: inline-flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  min-height: 36px;
  padding: 8px 13px;
  border: 1px solid var(--rule-strong);
  border-radius: 999px;
  color: var(--ink);
  font-family: var(--f-display);
  font-size: 12px;
  line-height: 1;
  letter-spacing: 0.08em;
  transition: background .35s, border-color .35s, color .35s, transform .35s;
  margin-top: auto;
}
.related-link-badges + .related-link-button,
.related-link-badges + .related-link-actions {
  margin-top: 0;
}
.related-link-actions .related-link-button { margin-top: 0; }
.related-link-dest + .related-link-button,
.related-link-dest + .related-link-actions {
  margin-top: 8px;
}
.related-link-button .arrow {
  width: 18px;
}
.related-link-button {
  background: var(--accent-soft);
  border-color: rgba(182, 85, 45, .28);
  color: var(--accent-deep);
}
.related-link-button:hover {
  background: var(--accent-deep);
  border-color: var(--accent-deep);
  color: var(--paper);
  transform: translateX(2px);
}
.related-link-card:hover .related-link-num,
.related-link-card:hover h3 {
  color: var(--accent-deep);
}
@media (max-width: 980px) {
  .related-links-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 640px) {
  .related-links-grid { grid-template-columns: 1fr; }
  .related-link-card { min-height: auto; }
}

/* =====================================================================
   Contact form
===================================================================== */
.contact-grid {
  display: grid;
  grid-template-columns: minmax(0, 0.7fr) minmax(0, 1.3fr);
  gap: clamp(40px, 5vw, 96px);
  align-items: start;
}
.contact-info { display: flex; flex-direction: column; gap: 20px; }
.contact-info h2 { line-height: 1.3; }
.contact-meta-list { display: flex; flex-direction: column; gap: 10px; padding-top: 8px; }
.contact-meta-list li {
  font-size: 14px; color: var(--ink-2); padding-left: 22px; position: relative;
}
.contact-meta-list li::before {
  content: ""; position: absolute; left: 0; top: 0.7em;
  width: 14px; height: 1px; background: var(--accent);
}

.form {
  background: var(--cream);
  padding: clamp(28px, 3vw, 52px);
  border-radius: 4px;
  border: 1px solid var(--rule);
  display: flex; flex-direction: column; gap: 22px;
}
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 22px; }
.form-required-note {
  margin: 0 0 2px;
  font-size: 12px;
  line-height: 1.7;
  letter-spacing: 0.06em;
  color: var(--ink-4);
}
.form-field { display: flex; flex-direction: column; gap: 8px; }
.form-field label,
.form-label {
  font-family: var(--f-display); font-size: 12.5px; font-weight: 500;
  letter-spacing: 0.12em; color: var(--ink-3); display: inline-flex; align-items: center; gap: 6px;
}
.form-field .req,
.form-label .req,
.form-required-note .req { color: var(--accent); }
.form-field input, .form-field select, .form-field textarea {
  background: var(--paper);
  border: 1px solid var(--rule);
  padding: 14px 16px;
  border-radius: 2px;
  font-size: 14.5px;
  color: var(--ink);
  transition: border-color .25s, background .25s;
  font-family: var(--f-display);
  letter-spacing: 0.04em;
}
.form-field input:focus, .form-field select:focus, .form-field textarea:focus {
  border-color: var(--accent); background: var(--paper);
}
.form-field textarea { min-height: 160px; resize: vertical; }
.form-submit {
  align-self: flex-start;
  display: inline-flex; align-items: center; gap: 14px;
  padding: 16px 32px; background: var(--ink); color: var(--paper);
  font-size: 13.5px; font-weight: 500; letter-spacing: 0.10em;
  border-radius: 999px; transition: background .25s, transform .35s;
}
.form-submit::after { content: "→"; }
.form-submit:hover { background: var(--accent); transform: translateY(-2px); }
.form-success {
  padding: 16px 18px; background: var(--accent-soft); color: var(--accent-deep);
  font-size: 13.5px; border-radius: 2px;
}
.form-error { font-size: 14px; color: #c0392b; padding: 12px 16px; background: #fdf0ef; border: 1px solid #e8b4b0; border-radius: 6px; }
.field-error { display: none; font-size: 12px; color: #c0392b; }
.field-error.show { display: block; }
input.input-invalid { border-color: #c0392b !important; }
.form-note { font-size: 12px; color: var(--ink-4); }
.form-radio-field { border: 0; padding: 0; margin: 0; }
.form-radio-group { display: flex; flex-direction: column; gap: 10px; }
.form-radio-label {
  display: flex; align-items: center; gap: 12px;
  font-family: var(--f-display); font-size: 13.5px; font-weight: 400;
  letter-spacing: 0.04em; color: var(--ink); cursor: pointer;
  padding: 12px 16px; border: 1px solid var(--rule); border-radius: 6px;
  transition: border-color .2s, background .2s;
}
.form-radio-label:hover { border-color: var(--accent); }
.form-radio-label input[type="radio"] {
  position: absolute;
  opacity: 0;
  width: 1px;
  height: 1px;
  margin: 0;
}
.form-radio-label .radio-mark {
  width: 18px; height: 18px; border-radius: 50%; flex-shrink: 0;
  border: 2px solid var(--rule); transition: border-color .2s, background .2s;
  box-shadow: inset 0 0 0 3px var(--paper);
}
.form-radio-label:has(input:checked) { border-color: var(--accent); background: color-mix(in srgb, var(--accent) 6%, transparent); }
.form-radio-label input[type="radio"]:checked ~ .radio-mark { border-color: var(--accent); background: var(--accent); }

@media (max-width: 800px) {
  .contact-grid, .form-row { grid-template-columns: 1fr; }
}

/* =====================================================================
   Map frame placeholder
===================================================================== */
.map-frame {
  aspect-ratio: 16/8;
  border-radius: 4px;
  border: 1px solid var(--rule);
  position: relative; overflow: hidden;
  background: var(--paper-2);
}
.map-frame iframe {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  border: 0; display: block;
}
.map-frame-caption {
  position: absolute; left: 22px; bottom: 22px;
  background: var(--paper); padding: 10px 16px; border-radius: 999px;
  font-family: var(--f-display); font-size: 13px; font-weight: 500; color: var(--ink);
  letter-spacing: 0.06em; box-shadow: var(--shadow-soft);
}

/* =====================================================================
   Footer
===================================================================== */
.footer {
  background: var(--ink); color: var(--paper);
  padding: clamp(64px, 7vw, 112px) 0 28px;
  position: relative;
  overflow: hidden;
}
.footer::before {
  content: "CAC";
  position: absolute; left: var(--pad-x); bottom: -60px;
  font-family: var(--f-display-en); font-weight: 300;
  font-size: clamp(160px, 28vw, 480px);
  color: rgba(244,241,234,.04);
  line-height: 1; letter-spacing: 0.04em;
  pointer-events: none;
}
.footer-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.7fr) repeat(3, minmax(0, 1fr));
  gap: clamp(32px, 4vw, 72px);
  position: relative;
}
.footer-brand-lockup { display: flex; align-items: center; gap: 18px; margin-bottom: 24px; }
.footer-brand-lockup img { width: 64px; height: 64px; object-fit: contain; filter: invert(1) brightness(2); opacity: .95; }
.footer-brand-text { display: flex; flex-direction: column; line-height: 1.1; gap: 9px; }
.footer-brand-name { font-family: var(--f-display); font-size: 17px; font-weight: 500; color: var(--paper); letter-spacing: 0.02em; }
.footer-brand-en { font-family: var(--f-display-en); font-size: 10.5px; font-weight: 300; color: rgba(244,241,234,.55); letter-spacing: 0.18em; text-transform: uppercase; }
.footer-brand-body { font-size: 13.5px; color: rgba(244,241,234,.7); line-height: 1.85; max-width: 34ch; margin-bottom: 14px; letter-spacing: 0.06em; }
.footer-address-line { display: inline-block; white-space: nowrap; }
.footer-col h4 {
  font-family: var(--f-display-en); font-size: 12px; font-weight: 300;
  color: rgba(244,241,234,.85); letter-spacing: 0.18em; text-transform: uppercase;
  margin-bottom: 18px;
  display: inline-flex; align-items: center; gap: 10px;
}
.footer-col h4::before { content: ""; width: 18px; height: 1px; background: var(--accent); }
.footer-col ul { display: flex; flex-direction: column; gap: 10px; }
.footer-col a {
  font-family: var(--f-display); font-size: 13.5px; color: rgba(244,241,234,.85);
  transition: color .25s; position: relative; display: inline-block;
  letter-spacing: 0.04em;
}
.footer-col a:hover { color: var(--accent); }
.footer-bottom {
  margin-top: clamp(56px, 6vw, 96px);
  padding-top: 28px;
  border-top: 1px solid rgba(244,241,234,.08);
  display: flex; justify-content: space-between; align-items: center;
  font-family: var(--f-display-en); font-size: 11px; font-weight: 300; color: rgba(244,241,234,.5);
  letter-spacing: 0.18em; text-transform: uppercase;
  position: relative;
}
.footer-bottom-links { display: flex; gap: 24px; }
.footer-bottom-links span:hover { color: var(--paper); cursor: pointer; }

@media (max-width: 800px) {
  .footer-grid { grid-template-columns: 1fr 1fr; }
  .footer-brand { grid-column: 1 / -1; }
  .footer-bottom { flex-direction: column; gap: 16px; }
}

/* =====================================================================
   Frame placeholder (replaceable by adding <img> inside)
===================================================================== */
.frame {
  position: relative;
  background: linear-gradient(135deg, #e8e2d5 0%, #d4ccba 100%);
  overflow: hidden;
  border-radius: 2px;
}
.frame::before {
  content: ""; position: absolute; inset: 14px;
  border: 1px solid rgba(22,20,15,.10);
  pointer-events: none;
  transition: opacity .3s;
}
.frame::after {
  content: attr(data-label);
  position: absolute; inset: 0;
  display: flex; align-items: center; justify-content: center;
  font-family: var(--f-display-en); font-size: 10.5px; font-weight: 300;
  letter-spacing: 0.32em; text-transform: uppercase;
  color: rgba(22,20,15,.36);
  pointer-events: none;
  text-align: center;
  padding: 16px;
}
.frame > img,
.frame > picture,
.frame > picture > img {
  width: 100%; height: 100%; object-fit: cover;
  display: block;
  position: relative; z-index: 2;
}
.frame:has(> img)::before, .frame:has(> img)::after,
.frame:has(> picture)::before, .frame:has(> picture)::after { display: none; }
/* Fallback for browsers without :has() ? class-based hide */
.frame.has-img::before, .frame.has-img::after { display: none; }

.frame--portrait  { aspect-ratio: 4/5; }
.frame--landscape { aspect-ratio: 16/10; }
.frame--square    { aspect-ratio: 1/1; }
.frame--tall      { aspect-ratio: 3/5; }

/* =====================================================================
   Hero v2 ? fiore inspired
===================================================================== */
.hero-v2 {
  padding: 0;
  position: relative;
  overflow: hidden;
  background: transparent;
  min-height: 100vh;
}
.hero-v2-photo {
  position: absolute; inset: 0;
  z-index: 0;
}
.hero-v2-photo .frame {
  width: 100%; height: 100%;
  aspect-ratio: unset;
  border-radius: 0;
}
.hero-v2-bg {
  position: absolute; inset: 0;
  z-index: 1;
  background:
    linear-gradient(to right, rgba(230,226,222,.72) 0%, rgba(230,226,222,.45) 45%, rgba(230,226,222,.10) 100%),
    radial-gradient(60% 80% at 80% 12%, rgba(182,85,45,.08), transparent 60%),
    radial-gradient(70% 90% at 12% 90%, rgba(52,70,58,.06),  transparent 60%);
  pointer-events: none;
}
.hero-v2-inner {
  position: relative;
  z-index: 2;
  max-width: 100%;
  margin: 0;
  padding: 0 var(--pad-x);
  display: flex;
  align-items: flex-start;
  min-height: 90vh;
  padding-top: calc(var(--nav-h) + 24px);
  padding-bottom: 72px;
}
.hero-v2-content {
  display: flex; flex-direction: column;
  align-items: flex-start;
  gap: 24px;
  width: 100%;
}
.hero-v2-left {
  display: flex; flex-direction: column;
  gap: 8px;
}
.hero-eyebrow {
  display: inline-flex; align-items: center; gap: 14px;
  font-family: var(--f-display-en);
  font-size: 12px;
  font-weight: 400;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--accent);
  margin-top: 32px;
}
.hero-eyebrow::before { content: ""; width: 28px; height: 1px; background: var(--accent); }

.hero-v2-headline {
  font-family: var(--f-display);
  font-weight: 300;
  color: var(--ink);
  line-height: 1.05;
  letter-spacing: 0.0em;
}
.hero-v2-headline .line-en {
  display: flex;
  flex-direction: column;
  gap: 6px;
  font-family: 'Montserrat', sans-serif;
  font-size: clamp(48px, 6vw, 96px);
  font-weight: 300;
  letter-spacing: -0.005em;
  line-height: 1.0;
  color: var(--ink-2);
}
.hero-v2-headline .line-en span {
  white-space: nowrap;
}
.hero-v2-headline .line-brand {
  display: inline-block;
  margin-top: clamp(20px, 2vw, 36px);
  font-family: 'Montserrat', sans-serif;
  font-size: clamp(18px, 1.4vw, 22px);
  font-weight: 400;
  letter-spacing: 0.42em;
  color: var(--accent);
  padding-left: 56px;
  position: relative;
}
.hero-v2-headline .line-brand::before {
  content: ""; position: absolute; left: 0; top: 50%; width: 44px; height: 1px; background: var(--accent);
}

.hero-v2-actions {
  display: flex; flex-direction: column; gap: 16px;
  flex-shrink: 0;
}

.hero-frame-a {
  will-change: transform;
  background-image: url('uploads/responsive/hero_bg-960.jpg');
  background-size: cover;
  background-position: center 40%;
}
.hero-frame-a::before { display: none; }

@media (max-width: 900px) {
  .hero-v2-inner { padding-top: calc(var(--nav-h) + 40px); }
  .hero-v2-content { flex-direction: column; gap: 32px; }
  .hero-v2-actions { flex-direction: row; flex-wrap: wrap; gap: 20px; padding-bottom: 0; }
}
@media (max-width: 600px) {
  .hero-v2 { min-height: 100svh; }
  .hero-v2-inner { min-height: 100svh; }
  .hero-v2-headline .line-en { font-size: clamp(40px, 13vw, 56px); }
}

/* Hero headline ? per-line staggered reveal */
.hero-v2-headline.reveal {
  opacity: 1 !important;
  transform: none !important;
  transition: none !important;
}
.hero-v2-headline .line-en span {
  opacity: 0;
  transform: translateY(40px);
  transition: opacity 1.1s cubic-bezier(.15,.7,.2,1), transform 1.1s cubic-bezier(.15,.7,.2,1);
}
.hero-v2-headline .line-brand {
  opacity: 0;
  transform: translateY(18px);
  transition: opacity .85s cubic-bezier(.2,.6,.2,1), transform .85s cubic-bezier(.2,.6,.2,1);
}
.hero-v2-headline.in .line-en span:nth-child(1) {
  opacity: 1;
  transform: translateY(0);
}
.hero-v2-headline.in .line-en span:nth-child(2) {
  opacity: 1;
  transform: translateY(0);
  transition-delay: .22s;
}
.hero-v2-headline.in .line-brand {
  opacity: 1;
  transform: translateY(0);
  transition-delay: .45s;
}

/* =====================================================================
   Bilingual section heading
===================================================================== */
.bilingual-section { position: relative; }
.bilingual-head {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  margin-bottom: clamp(48px, 6vw, 96px);
  gap: 8px;
}
.bilingual-head--center { align-items: center; text-align: center; }

.bilingual-en {
  font-family: 'Montserrat', sans-serif;
  font-size: clamp(34px, 5vw, 64px);
  font-weight: 300;
  letter-spacing: 0.04em;
  color: var(--accent);
  line-height: 1.1;
  font-style: normal;
}
.bilingual-jp {
  font-family: var(--f-display);
  font-size: clamp(13px, 1vw, 14px);
  font-weight: 500;
  letter-spacing: 0.32em;
  color: var(--ink);
  margin-top: 4px;
  white-space: nowrap;
  word-break: keep-all;
  position: relative;
  padding-bottom: 24px;
}
.bilingual-jp::after {
  content: ""; position: absolute; left: 50%; bottom: 0; transform: translateX(-50%);
  width: 32px; height: 1px; background: var(--accent);
}
.bilingual-lead {
  margin-top: 28px;
  font-size: 15px; line-height: 1.95;
  color: var(--ink);
  max-width: 56ch;
  letter-spacing: 0.08em;
}

.section-tinted { background: rgba(244, 241, 234, .55); }

/* =====================================================================
   Philosophy
===================================================================== */
.philosophy-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(0, 1fr);
  gap: clamp(40px, 6vw, 96px);
  align-items: start;
}
.philosophy-text {
  display: flex; flex-direction: column; gap: 18px;
  max-width: 52ch;
}
.philosophy-text .lead {
  font-family: var(--f-display);
  font-size: clamp(18px, 2.4vw, 26px);
  font-weight: 500;
  color: var(--ink);
  line-height: 1.7;
  letter-spacing: 0.10em;
  margin-bottom: 16px;
}
.philosophy-text .lead .no-wrap {
  white-space: nowrap;
}
.philosophy-text .lead em.hl {
  font-style: normal;
  background: linear-gradient(to top, var(--accent-soft) 32%, transparent 32%);
  padding: 0 0.08em;
}
.philosophy-text p { font-size: 15px; line-height: 1.92; color: var(--ink); letter-spacing: 0.08em; }
.philosophy-text .btn-ghost { align-self: flex-start; margin-top: 8px; }
.philosophy-mini-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
  width: min(100%, 520px);
  margin-top: 18px;
}
.philosophy-mini-frame {
  width: 100%;
  aspect-ratio: 1;
}

.philosophy-frames {
  position: relative;
}
.philosophy-frame-a {
  width: 100%;
}
@media (max-width: 800px) {
  .philosophy-grid { grid-template-columns: 1fr; }
  .philosophy-mini-grid { width: min(100%, 520px); }
}

/* =====================================================================
   Pickup cards
===================================================================== */
.pickup-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: clamp(20px, 2.4vw, 36px);
}
.pickup-card {
  display: flex; flex-direction: column;
  gap: 20px;
  position: relative;
  padding: 28px 24px 32px;
  border: 1px solid rgba(78,68,73,.12);
  border-bottom: 2px solid rgba(78,68,73,.18);
  background: rgba(244,241,234,.45);
  text-decoration: none;
  transition: background .35s, border-color .35s;
}
.pickup-card::before {
  content: ""; position: absolute; left: 0; top: 0; height: 100%;
  width: 0; background: var(--accent); transition: width .45s cubic-bezier(.6,0,.2,1);
}
.pickup-card:hover {
  background: var(--accent-hover);
  border-color: var(--accent-hover-border);
  border-bottom-color: var(--accent);
}
.pickup-card:hover::before { width: 3px; }
.pickup-num {
  font-family: 'Montserrat', sans-serif;
  font-size: 11px; font-weight: 400;
  letter-spacing: 0.36em;
  color: var(--ink-4);
  display: block;
  transition: color .35s;
}
.pickup-card:hover .pickup-num { color: var(--accent); }
.pickup-meta { display: flex; flex-direction: column; gap: 8px; flex: 1; }
.pickup-en {
  font-family: 'Montserrat', sans-serif;
  font-size: 11px; font-weight: 400;
  letter-spacing: 0.24em; text-transform: uppercase;
  color: var(--accent);
}
.pickup-title {
  font-family: var(--f-display);
  font-size: clamp(17px, 1.6vw, 21px);
  font-weight: 500;
  color: var(--ink);
  letter-spacing: 0.10em;
  line-height: 1.5;
  transition: color .35s;
}
.pickup-card:hover .pickup-title { color: var(--accent-deep); }
.pickup-body {
  font-family: var(--f-body);
  font-size: 13px; line-height: 1.85;
  color: var(--ink-4);
  letter-spacing: 0.03em;
  margin-top: 6px;
}
.pickup-arrow {
  position: absolute; top: 20px; right: 20px;
  width: 32px; height: 32px; border-radius: 50%;
  background: rgba(78,68,73,.08);
  border: 1px solid rgba(78,68,73,.15);
  display: flex; align-items: center; justify-content: center;
  z-index: 3;
  transition: background .35s, color .35s, border-color .35s, transform .35s;
}
.pickup-arrow::after {
  content: "→"; font-size: 13px; color: var(--ink);
}
.pickup-card:hover .pickup-arrow {
  background: var(--accent); border-color: var(--accent); transform: scale(1.06);
}
.pickup-card:hover .pickup-arrow::after { color: var(--paper); }
.pickup-photo-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
  width: min(100%, 520px);
  margin: clamp(32px, 4vw, 54px) auto 0;
}
@media (max-width: 900px) { .pickup-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 540px) { .pickup-grid { grid-template-columns: 1fr; } }

/* =====================================================================
   Business service blocks (01..04 alternating)
===================================================================== */
.service-block {
  display: grid;
  grid-template-columns: 80px minmax(0, 0.85fr) minmax(0, 1.15fr);
  gap: clamp(28px, 4vw, 72px);
  align-items: start;
  padding: clamp(48px, 6vw, 96px) 0;
  position: relative;
}
.service-block + .service-block { border-top: 1px solid var(--rule); }
.service-num {
  display: flex; flex-direction: column; gap: 8px;
  padding-top: 6px;
}
.service-num .num {
  font-family: 'Montserrat', sans-serif;
  font-size: clamp(36px, 4vw, 56px); font-weight: 300;
  color: var(--ink-3); letter-spacing: 0.02em;
  line-height: 1;
}
.service-num .en {
  font-family: 'Montserrat', sans-serif;
  font-size: 11px; font-weight: 400;
  letter-spacing: 0.32em; text-transform: uppercase;
  color: var(--accent);
}
.service-text { display: flex; flex-direction: column; gap: 18px; }
.service-text h3 {
  font-family: var(--f-display);
  font-size: clamp(22px, 2.6vw, 32px);
  font-weight: 500;
  color: var(--ink);
  line-height: 1.4;
  letter-spacing: 0.12em;
}
.service-text p { font-size: 15px; line-height: 1.95; color: var(--ink); letter-spacing: 0.08em; max-width: 42ch; }
.service-text .btn-ghost { align-self: flex-start; margin-top: 8px; }

.service-frames { position: relative; }
.service-frame-main { width: 100%; }
.service-frame-sub {
  position: absolute;
  right: -8%; bottom: -10%;
  width: 38%;
  z-index: 2;
}
/* Alt block ? image left, text right */
.service-block--alt {
  grid-template-columns: minmax(0, 1.15fr) minmax(0, 0.85fr) 80px;
}
.service-block--alt .service-num { order: 3; align-items: flex-end; }
.service-block--alt .service-text { order: 2; }
.service-block--alt .service-frames { order: 1; }
.service-block--alt .service-frame-sub {
  right: auto; left: -8%; bottom: -10%;
}
.service-frame-sub--left {
  right: auto; left: -8%; bottom: -10%;
}

@media (max-width: 900px) {
  .service-block, .service-block--alt {
    grid-template-columns: 1fr;
    gap: 28px;
  }
  .service-block--alt .service-num { order: 0; align-items: flex-start; }
  .service-block--alt .service-text { order: 1; }
  .service-block--alt .service-frames { order: 2; }
  .service-frame-sub { position: static; width: 60%; margin-left: auto; margin-top: -40px; }
  .service-block--alt .service-frame-sub,
  .service-frame-sub--left { margin-left: 0; margin-right: auto; }
}

/* =====================================================================
   Topics two-column layout
===================================================================== */
.topics-layout {
  display: grid;
  grid-template-columns: minmax(0, 0.35fr) minmax(0, 1fr);
  gap: clamp(32px, 4vw, 80px);
  align-items: start;
}
.topics-cats .caption {
  font-family: 'Montserrat', sans-serif;
  font-size: 11px; font-weight: 400;
  letter-spacing: 0.32em; text-transform: uppercase;
  color: var(--ink-3);
  margin-bottom: 18px;
}
.topics-cats ul { display: flex; flex-direction: column; gap: 14px; }
.topics-cats a {
  font-family: var(--f-display);
  font-size: 14px; font-weight: 500;
  color: var(--ink); letter-spacing: 0.10em;
  padding-left: 16px; position: relative;
  transition: color .25s, padding-left .25s;
}
.topics-cats a::before {
  content: ""; position: absolute; left: 0; top: 50%;
  width: 8px; height: 1px; background: var(--accent);
  transition: width .25s;
}
.topics-cats a:hover { color: var(--accent); padding-left: 22px; }
.topics-cats a:hover::before { width: 14px; }
@media (max-width: 800px) { .topics-layout { grid-template-columns: 1fr; } }

/* =====================================================================
   Contact CTA with frame background
===================================================================== */
.contact-cta {
  position: relative;
  padding: clamp(120px, 14vw, 200px) 0;
  overflow: hidden;
}
.contact-cta-bg {
  position: absolute; inset: 0;
  z-index: 0;
  border-radius: 0;
  aspect-ratio: auto;
}
.contact-cta-bg::before { display: none; }
.contact-cta-bg::after {
  inset: 0;
  background: linear-gradient(180deg, rgba(22,20,15,.32) 0%, rgba(22,20,15,.52) 100%);
  color: rgba(244,241,234,.55);
  font-size: 11px;
  pointer-events: none;
}
.contact-cta-inner {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  color: var(--paper);
  gap: 8px;
}
.contact-cta-inner .bilingual-en {
  color: var(--accent-soft);
}
.contact-cta-inner .bilingual-jp {
  color: var(--paper);
}
.contact-cta-inner .bilingual-jp::after { background: var(--accent-soft); }
.contact-cta-body {
  font-size: 15px; line-height: 1.95;
  color: rgba(244,241,234,.92);
  max-width: min(100%, 72ch);
  letter-spacing: 0.08em;
  margin: 24px 0 8px;
}
.contact-cta-nowrap {
  display: inline-block;
  white-space: nowrap;
}
@media (max-width: 760px) {
  .contact-cta-nowrap {
    white-space: normal;
  }
}
.contact-cta-actions { display: flex; gap: 18px; flex-wrap: wrap; justify-content: center; margin-top: 32px; }
.contact-cta-actions .btn-primary { background: var(--accent); border-color: var(--accent); }
.contact-cta-actions .btn-primary:hover { background: var(--paper); color: var(--ink); border-color: var(--paper); }
.contact-cta-actions .btn-secondary { background: transparent; color: var(--paper); border-color: rgba(244,241,234,.5); }
.contact-cta-actions .btn-secondary:hover { background: var(--paper); color: var(--ink); border-color: var(--paper); }

/* =====================================================================
   Regulations page
===================================================================== */
.reg-tabs {
  display: flex;
  gap: 0;
  border-bottom: 2px solid var(--rule);
  margin-bottom: 48px;
  flex-wrap: wrap;
}
.reg-tab-btn {
  font-family: var(--f-body);
  font-size: 13.5px;
  font-weight: 500;
  letter-spacing: 0.06em;
  color: var(--ink-3);
  padding: 14px 32px 14px 32px;
  background: none;
  border: none;
  border-bottom: 2px solid transparent;
  margin-bottom: -2px;
  cursor: pointer;
  transition: color 0.2s, background 0.2s;
  white-space: nowrap;
  position: relative;
}
.reg-tab-btn:first-child { padding-left: 0; }
.reg-tab-btn + .reg-tab-btn::before {
  content: '';
  position: absolute;
  left: 0;
  top: 20%;
  height: 60%;
  width: 1px;
  background: var(--rule);
}
.reg-tab-btn:hover { color: var(--ink); }
.reg-tab-btn.active {
  color: var(--ink);
  border-bottom-color: var(--accent);
}
.reg-tab-panel { display: none; }
.reg-tab-panel.active { display: block; }

.reg-org {
  display: flex; align-items: baseline; gap: 16px;
  padding: 20px 24px;
  background: var(--paper-2);
  border-left: 3px solid var(--accent);
  margin-bottom: 48px;
  border-radius: 0 2px 2px 0;
}
.reg-org-label {
  font-family: var(--f-display-en); font-size: 11px; font-weight: 400;
  letter-spacing: 0.18em; text-transform: uppercase; color: var(--ink-4);
  white-space: nowrap;
}
.reg-org-name {
  font-family: var(--f-display); font-size: 15px; font-weight: 500;
  color: var(--ink); letter-spacing: 0.08em;
}

.reg-article {
  border-top: 1px solid var(--rule);
  padding: clamp(32px, 4vw, 56px) 0;
}
.reg-article:last-child { border-bottom: 1px solid var(--rule); }

.reg-article-head {
  display: flex; align-items: baseline; gap: 20px;
  margin-bottom: 28px;
}
.reg-num {
  font-family: var(--f-display-en); font-size: 11px; font-weight: 500;
  letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--paper); background: var(--ink);
  padding: 4px 10px; border-radius: 2px;
  white-space: nowrap; flex-shrink: 0;
}
.reg-title {
  font-family: var(--f-display); font-size: clamp(16px, 2vw, 20px);
  font-weight: 500; color: var(--ink); letter-spacing: 0.10em;
}

.reg-body { display: flex; flex-direction: column; gap: 20px; }
.reg-body > p {
  font-size: 14.5px; line-height: 2; color: var(--ink-2); letter-spacing: 0.06em;
}

.reg-item {
  display: grid;
  grid-template-columns: 52px 1fr;
  gap: 0 12px;
  align-items: start;
}
.reg-item-num {
  font-family: var(--f-display); font-size: 13.5px; font-weight: 500;
  color: var(--ink-4); letter-spacing: 0.04em;
  padding-top: 2px; white-space: nowrap;
}
.reg-item p {
  font-size: 14.5px; line-height: 2; color: var(--ink-2); letter-spacing: 0.06em;
  margin: 0;
}
.reg-item p + p { margin-top: 8px; }

.reg-sublist {
  margin: 12px 0 0 0; padding: 0;
  display: flex; flex-direction: column; gap: 8px;
  list-style: none; counter-reset: reg-sub;
}
.reg-sublist li {
  display: flex; align-items: baseline; gap: 10px;
  font-size: 14px; line-height: 1.8; color: var(--ink-2); letter-spacing: 0.06em;
  counter-increment: reg-sub;
}
.reg-sublist li::before {
  content: "(" counter(reg-sub) ")";
  font-size: 12px; color: var(--ink-4); white-space: nowrap; flex-shrink: 0;
  min-width: 28px;
}

@media (max-width: 640px) {
  .reg-item { grid-template-columns: 44px 1fr; }
  .reg-article-head { gap: 12px; }
}

/* =====================================================================
   Reveal animations
===================================================================== */
.reveal {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity .9s cubic-bezier(.2,.6,.2,1), transform .9s cubic-bezier(.2,.6,.2,1);
}
.reveal.in {
  opacity: 1; transform: translateY(0);
}
.reveal-stagger > * {
  opacity: 0; transform: translateY(24px);
  transition: opacity .8s cubic-bezier(.2,.6,.2,1), transform .8s cubic-bezier(.2,.6,.2,1);
}
.reveal-stagger.in > * { opacity: 1; transform: translateY(0); }
.reveal-stagger.in > *:nth-child(1) { transition-delay: .08s; }
.reveal-stagger.in > *:nth-child(2) { transition-delay: .16s; }
.reveal-stagger.in > *:nth-child(3) { transition-delay: .24s; }
.reveal-stagger.in > *:nth-child(4) { transition-delay: .32s; }
.reveal-stagger.in > *:nth-child(5) { transition-delay: .40s; }
.reveal-stagger.in > *:nth-child(6) { transition-delay: .48s; }

/* Mask reveal ? used on images */
.mask-reveal {
  position: relative; overflow: hidden;
}
.mask-reveal::after {
  content: ""; position: absolute; inset: 0; z-index: 3; background: var(--paper);
  transform-origin: right center;
  transform: scaleX(1);
  transition: transform 1.1s cubic-bezier(.7,0,.2,1);
}
.mask-reveal.in::after { transform: scaleX(0); }
/* .frame:has(> img)::after が display:none にするのを mask-reveal では上書き */
.frame.mask-reveal:has(> img)::after,
.frame.mask-reveal.has-img::after { display: block; }

/* Char-split title (set up in JS) */
.split-char {
  display: inline-block;
  transform: translateY(110%);
  opacity: 0;
  transition: transform .9s cubic-bezier(.2,.6,.2,1), opacity .6s linear;
}
.split-line { overflow: hidden; display: inline-block; }
.in .split-char {
  transform: translateY(0); opacity: 1;
}
.in .split-char:nth-child(1) { transition-delay: .05s; }
.in .split-char:nth-child(2) { transition-delay: .09s; }
.in .split-char:nth-child(3) { transition-delay: .13s; }
.in .split-char:nth-child(4) { transition-delay: .17s; }
.in .split-char:nth-child(5) { transition-delay: .21s; }
.in .split-char:nth-child(6) { transition-delay: .25s; }
.in .split-char:nth-child(7) { transition-delay: .29s; }
.in .split-char:nth-child(8) { transition-delay: .33s; }
.in .split-char:nth-child(9) { transition-delay: .37s; }
.in .split-char:nth-child(10) { transition-delay: .41s; }
.in .split-char:nth-child(11) { transition-delay: .45s; }
.in .split-char:nth-child(12) { transition-delay: .49s; }

/* Cursor follower (subtle) */
.cursor-dot {
  position: fixed; top: 0; left: 0; width: 12px; height: 12px;
  background: var(--accent); border-radius: 50%;
  pointer-events: none; z-index: 9999;
  transform: translate(-50%, -50%);
  mix-blend-mode: multiply;
  transition: width .35s cubic-bezier(.4,1.4,.5,1), height .35s cubic-bezier(.4,1.4,.5,1), opacity .25s;
  opacity: 0;
}
.cursor-dot.show { opacity: 1; }
.cursor-dot.hover { width: 60px; height: 60px; background: var(--accent); opacity: .35; }
@media (pointer: coarse) { .cursor-dot { display: none; } }

/* Scroll progress bar */
.scroll-progress {
  position: fixed; top: 0; left: 0; height: 2px; z-index: 101;
  background: var(--accent);
  width: 0%;
  transition: width .15s linear;
}
.scroll-cue {
  position: fixed;
  right: clamp(14px, 2.2vw, 34px);
  top: 50%;
  z-index: 90;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
  color: rgba(74, 68, 61, .72);
  pointer-events: none;
  transform: translateY(-50%);
  opacity: 1;
  transition: opacity .35s ease, transform .35s ease;
}
.scroll-cue.is-hidden {
  opacity: 0;
  transform: translateY(-50%) translateX(8px);
}
.scroll-cue-text {
  writing-mode: vertical-rl;
  font-family: var(--f-en);
  font-size: 10px;
  line-height: 1;
  letter-spacing: .28em;
  text-transform: uppercase;
}
.scroll-cue-line {
  position: relative;
  width: 1px;
  height: 72px;
  overflow: hidden;
  background: rgba(74, 68, 61, .24);
}
.scroll-cue-line span {
  position: absolute;
  left: 0;
  top: -40%;
  width: 100%;
  height: 36%;
  background: var(--accent);
  animation: scrollCueDrop 1.6s cubic-bezier(.6, 0, .2, 1) infinite;
}
@keyframes scrollCueDrop {
  0% { transform: translateY(-120%); opacity: 0; }
  20% { opacity: 1; }
  80% { opacity: 1; }
  100% { transform: translateY(330%); opacity: 0; }
}
@media (max-width: 900px) {
  .scroll-cue { display: none; }
}
@media (prefers-reduced-motion: reduce) {
  .scroll-cue-line span {
    top: 0;
    animation: none;
  }
}

/* Font load gate disabled ? fonts use display: swap so body shows immediately */

/* ── Fee Table ──────────────────────────────────────────────────── */
.fee-table-wrap {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  margin-bottom: 32px;
}
.fee-table {
  width: 100%;
  min-width: 700px;
  border-collapse: collapse;
  font-size: 13px;
  font-family: var(--f-body);
  color: var(--ink);
}

.fee-table caption {
  position: absolute;
  width: 1px;
  height: 1px;
  overflow: hidden;
  clip: rect(0 0 0 0);
  white-space: nowrap;
}

.fee-table th,
.fee-table td {
  border: 1px solid var(--rule-strong);
  padding: 7px 10px;
  vertical-align: middle;
  line-height: 1.5;
}
.fee-table thead th {
  background: var(--paper-2);
  font-weight: 600;
  text-align: center;
  font-size: 12px;
}
.fee-table .fee-cat {
  background: var(--paper-2);
  font-weight: 600;
  text-align: center;
  font-size: 12.5px;
  white-space: nowrap;
}
.fee-table .fee-num {
  text-align: right;
  white-space: nowrap;
  font-family: var(--f-en);
  letter-spacing: .02em;
}
.fee-table .fee-note {
  font-size: 12px;
  color: var(--ink-3);
}
.fee-table tr.fee-subtotal td {
  background: var(--paper-2);
  font-weight: 600;
  border-top: 1px solid var(--rule-strong);
}
.fee-table tr.fee-total td {
  background: var(--paper-3);
  font-weight: 700;
  border-top: 2px solid var(--rule-strong);
}
.fee-notes {
  margin-top: 20px;
}
.fee-notes p {
  font-size: 12.5px;
  color: var(--ink-3);
  line-height: 1.7;
  margin-bottom: 4px;
}

/* === Back to Top === */
.back-top {
  position: fixed;
  bottom: 32px;
  right: 32px;
  z-index: 900;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 5px;
  padding: 12px 14px;
  background: var(--paper);
  border: 1px solid var(--rule-strong);
  border-radius: 4px;
  color: var(--ink-3);
  font-family: var(--f-display);
  font-size: 9px;
  font-weight: 600;
  letter-spacing: 0.18em;
  cursor: pointer;
  opacity: 0;
  transform: translateY(10px);
  transition: opacity .4s, transform .4s, background .25s, color .25s, border-color .25s;
  pointer-events: none;
  box-shadow: 0 2px 12px rgba(22,20,15,.10);
}
.back-top.visible {
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}
.back-top:hover {
  background: var(--accent);
  color: var(--paper);
  border-color: var(--accent);
}
@media (max-width: 640px) {
  .back-top { bottom: 20px; right: 16px; }
}
html.fonts-loading body, html.fonts-loaded body { opacity: 1; }

/* ===== 翻訳時のテキスト折り返し修正（全ページ） ===== */
/* data-ui-lang が付いている = 非JA言語が選択中。html[lang] は GT が上書きするため使わない */
html[data-ui-lang] .no-wrap,
html[data-ui-lang] .contact-cta-nowrap,
html[data-ui-lang] .hero-title-display,
html[data-ui-lang] .sec-head h2,
html[data-ui-lang] .sec-head--offset h2,
html[data-ui-lang] .manifesto-quote,
html[data-ui-lang] .history-timeline .process-step p,
html[data-ui-lang] .quote-bar blockquote,
html[data-ui-lang] .cta-block h2 > span,
html[data-ui-lang] .page-head-title,
html[data-ui-lang] .hero-v2-headline .line-en span,
html[data-ui-lang] .bilingual-jp {
  white-space: normal !important;
  overflow-wrap: break-word !important;
  word-break: break-word !important;
}

/* ===== Google Translate UI 非表示 ===== */
.goog-te-banner-frame,
.goog-te-menu-value,
#goog-gt-tt,
.goog-te-balloon-frame,
div#goog-gt-tt,
.skiptranslate { display: none !important; }
body { top: 0 !important; }

/* ===== モバイル表示修正 ===== */
@media (max-width: 800px) {
  /* page-head-bg--wide: モバイルで横スクロール防止 */
  .page-head-bg--wide img { width: 100%; max-width: 100%; }

  /* ナビ: ロゴ・テキスト縮小 / nav-brand を縮小可能にしてハンバーガーを確保 */
  .nav-brand { min-width: 0; flex-shrink: 1; overflow: hidden; }
  .nav-brand-lockup {
    width: min(292px, calc(100vw - 92px));
    height: 48px;
  }

  /* ヒーロータイトル: nowrap解除（700-800px対応） */
  .hero-title-display { white-space: normal; }

  /* ページヘッダー: タイトル折り返し・リード幅解除 */
  .page-head-title { white-space: normal; }
  .page-head-lead { max-width: 100%; font-size: 14.5px; }
  .page-head-lead br { display: none; }

  /* セクション見出し: 折り返し許可 */
  .bilingual-jp { white-space: normal; }

  /* リード文: 幅制限解除・強制改行を自然折り返しへ */
  .bilingual-lead { max-width: 100%; font-size: 14px; }
  .bilingual-lead br { display: none; }

  /* フッター: ロゴ縮小 */
  .footer-brand-lockup { gap: 14px; }
  .footer-brand-lockup img { width: 48px; height: 48px; }
  .footer-brand-name { font-size: 15px; }

  /* 住所: 横スクロール防止 */
  .footer-address-line { white-space: normal; }

  /* about ページの沿革タイムライン: nowrap解除 */
  .history-timeline .process-step p { white-space: normal; }
}

@media (max-width: 480px) {
  /* 極小画面: ナビロゴさらに縮小 */
  .nav-brand-lockup {
    width: min(250px, calc(100vw - 84px));
    height: 42px;
  }
}

/* ===== 印刷スタイル ===== */
@media print {
  .nav, .mobile-menu, .hamburger, .back-top, .scroll-progress,
  .scroll-cue, .side-rail, .lang, .nav-cta, .footer-bottom-links { display: none !important; }
  body { background: #fff; color: #000; font-size: 12pt; }
  .footer { border-top: 1pt solid #ccc; padding: 12pt 0; }
  .footer-brand-body, .footer-col { font-size: 9pt; }
  .footer-col a { color: #000; text-decoration: none; }
  .container { max-width: 100%; padding: 0 16pt; }
  a[href]::after { content: " (" attr(href) ")"; font-size: 8pt; color: #666; }
  a[href^="#"]::after, a[href^="mailto:"]::after, a[href^="tel:"]::after { content: ""; }
  .reg-article, .reg-item { page-break-inside: avoid; }
  h1, h2, h3 { page-break-after: avoid; }
}

/* ===== 翻訳時：ナビリンクをハンバーガーに切り替え ===== */
@media (min-width: 1101px) {
  html[data-ui-lang] .nav-links { display: none !important; }
  html[data-ui-lang] .nav-right { margin-left: auto; }
  html[data-ui-lang] .hamburger {
    display: flex !important;
    visibility: visible;
    flex-direction: column; gap: 5px;
    width: 32px; height: 32px;
    justify-content: center; align-items: center; padding: 0;
    margin-left: 14px;
  }
  html[data-ui-lang] .hamburger span {
    display: block !important;
    width: 18px; height: 1.5px;
    background: var(--ink);
    transition: transform .35s;
  }
  html[data-ui-lang] .mobile-menu {
    inset: var(--nav-h) 0 auto auto;
    width: 320px;
    border-radius: 0 0 10px 10px;
    box-shadow: 0 8px 28px rgba(0,0,0,0.13);
    padding: 20px 28px;
    gap: 4px;
  }
  html[data-ui-lang] .mobile-menu a {
    font-size: 14px;
  }
  html[data-ui-lang] .mobile-menu a small {
    font-size: 9.5px;
  }
  html[data-ui-lang] .mobile-menu .lang { display: none; }
  html[data-ui-lang] .mobile-menu .nav-cta { display: none; }
}

/* Inline style replacements for CSP */
.u-border-top { border-top: 1px solid var(--rule); }
.u-bg-paper-2 { background: var(--paper-2); }
.u-bg-paper-2-border-top { border-top: 1px solid var(--rule); background: var(--paper-2); }
.u-max-880 { max-width: 880px; }
.u-max-900 { max-width: 900px; }
.u-max-900-center { max-width: 900px; margin: 0 auto; }
.u-max-960 { max-width: 960px; }
.u-max-1080 { max-width: 1080px; }
.u-mt-12 { margin-top: 12px; }
.u-mt-16 { margin-top: 16px; }
.u-mt-24 { margin-top: 24px; }
.u-mt-64 { margin-top: 64px; }
.u-center-mt-48 { text-align: center; margin-top: 48px; }
.u-text-center { text-align: center; }
.u-text-right-muted { text-align: right; margin-top: 32px; opacity: .55; }
.u-footer-note { font-size: 12.5px; opacity: .55; }
.u-info-en { color: var(--ink-4); font-size: 13px; font-family: var(--f-display); font-style: italic; }
.u-contact-title { font-family: var(--f-display); font-size: clamp(16px, 2.2vw, 32px); font-weight: 300; color: var(--ink); line-height: 1.18; letter-spacing: 0.10em; margin-top: 8px; }
.u-contact-box { padding-top: 24px; border-top: 1px solid var(--rule); margin-top: 16px; }
.u-contact-label { letter-spacing: 0.24em; text-transform: uppercase; margin-bottom: 8px; font-family: var(--f-en); }
.u-contact-label-spaced { letter-spacing: 0.24em; text-transform: uppercase; margin: 22px 0 8px; font-family: var(--f-en); }
.u-font-14 { font-size: 14px; }
.u-flow-small { display: block; font-family: var(--f-jp); font-size: 12px; color: var(--ink-3); font-style: normal; margin-top: 4px; }
.u-placement-note { margin-bottom: 28px; color: var(--ink-3); font-size: 13.5px; }
.u-muted-13 { font-size: 13px; color: var(--ink-3); }
.u-ol-mt-12 { margin-top: 12px; }
.u-privacy-heading { font-weight: 600; margin-bottom: 6px; }
.u-privacy-list { margin-top: 8px; padding-left: 1.4em; line-height: 1.9; }
.u-privacy-contact { margin-top: 12px; padding: 16px 20px; background: var(--surface); border-radius: 8px; line-height: 2; }
.u-services-head-grid { grid-template-columns: minmax(0, 1.2fr) minmax(0, 0.8fr); }
.u-services-pillars-grid { grid-template-columns: repeat(3, 1fr); }
.u-system-caption { margin-bottom: 18px; letter-spacing: 0.24em; text-transform: uppercase; color: var(--ink-3); }

/* Sitemap page */
.sitemap-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 32px 40px;
  margin-top: 48px;
}
.sitemap-group h2 {
  font-family: var(--f-display-en);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--ink-3);
  border-bottom: 1px solid var(--rule);
  padding-bottom: 10px;
  margin-bottom: 14px;
}
.sitemap-group ul { display: flex; flex-direction: column; gap: 10px; }
.sitemap-group ul li a {
  font-size: 13.5px;
  color: var(--ink-2);
  transition: color .2s;
  white-space: nowrap;
}
.sitemap-group ul li a:hover { color: var(--accent); }
.sitemap-group ul li small {
  display: block;
  font-family: var(--f-display-en);
  font-size: 10px;
  color: var(--ink-4);
  letter-spacing: 0.14em;
  margin-top: 2px;
}
.sitemap-group--legal {
  grid-column: 1 / -1;
  border-top: 1px solid var(--rule);
  padding-top: 32px;
  margin-top: 8px;
}
.sitemap-group--legal ul {
  flex-direction: row;
  flex-wrap: wrap;
  gap: 12px 48px;
}

/* Systems page */
.system-block {
  display: grid;
  grid-template-columns: minmax(0, 0.42fr) minmax(0, 1.58fr);
  gap: clamp(32px, 5vw, 96px);
  align-items: start;
}
.system-block-side {
  position: sticky;
  top: calc(var(--nav-h) + 24px);
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.system-block-side .num {
  font-family: var(--f-display-en);
  font-size: clamp(40px, 5vw, 64px);
  line-height: 1;
  color: var(--ink-3);
  font-weight: 300;
  letter-spacing: 0.04em;
}
.system-block-side h2 {
  font-family: var(--f-display);
  font-size: clamp(24px, 4vw, 46px);
  font-weight: 300;
  color: var(--ink);
  letter-spacing: 0.10em;
  line-height: 1.18;
  margin-top: 8px;
}
.system-block-side .en {
  font-family: var(--f-display-en);
  font-size: 12px;
  font-weight: 300;
  color: var(--ink-3);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  margin-top: 12px;
}
.system-block-body { display: flex; flex-direction: column; gap: 28px; }
@media (max-width: 800px) {
  .system-block { grid-template-columns: 1fr; }
  .system-block-side { position: static; }
}

[data-parallax] { will-change: transform; }
