/* ==========================================================================
   一刻舎 Ikkokusha — コーポレートサイト スタイル
   墨と土 (Ink & Earth) デザインシステムのトークンを自己完結で同梱。
   ソースの design_system/ には依存しない（必要なトークンだけ取り込み）。
   ========================================================================== */

/* ---- Design tokens : Colors（墨と土） --------------------------------------- */
:root {
  /* Paper / earth neutrals */
  --paper-0:  #FBF8F1;
  --paper-1:  #F4EFE6;
  --paper-2:  #ECE4D6;
  --paper-3:  #E0D6C4;
  --sand:     #DDD3C2;

  /* Sumi ink scale */
  --sumi-0:   #1F1B16;
  --sumi-1:   #3A3329;
  --nezumi:   #5C5346;
  --nezumi-2: #8A7E6D;
  --sumi-line:#C7BBA6;

  /* 弁柄 Bengara — primary accent */
  --bengara:      #A8492F;
  --bengara-dark: #8C3A24;
  --bengara-soft: #C26A4F;
  --bengara-tint: #F0DDD3;

  /* 黄土 Ōdo — secondary warm */
  --odo:      #C98A4B;
  --odo-dark: #A86F36;
  --odo-tint: #F3E6CE;

  /* Semantic hues */
  --kokei:        #6E7A4F;
  --kokei-dark:   #58633E;
  --kokei-tint:   #E7E8D6;
  --ai:           #3B5566;
  --ai-dark:      #2C4150;
  --ai-tint:      #DCE4E8;
  --kohaku:       #B8852E;
  --kohaku-tint:  #F4E8CC;
  --hi:           #9E3B2E;
  --hi-dark:      #822E23;
  --hi-tint:      #F1D9D4;

  /* Semantic aliases */
  --text-primary:   var(--sumi-0);
  --text-strong:    var(--sumi-1);
  --text-secondary: var(--nezumi);
  --text-tertiary:  var(--nezumi-2);
  --text-accent:    var(--bengara);
  --text-inverse:   var(--paper-0);
  --text-on-accent: var(--paper-0);

  --surface-page:    var(--paper-1);
  --surface-card:    var(--paper-0);
  --surface-sunken:  var(--paper-2);
  --surface-muted:   var(--paper-3);
  --surface-inverse: var(--sumi-0);
  --surface-accent:  var(--bengara);
  --surface-accent-soft: var(--bengara-tint);

  --border-subtle:  #E7DECE;
  --border-default: var(--sand);
  --border-strong:  var(--sumi-line);
  --border-ink:     var(--sumi-0);
  --border-accent:  var(--bengara);

  --accent:          var(--bengara);
  --accent-hover:    var(--bengara-dark);
  --accent-contrast: var(--paper-0);

  --focus-ring: color-mix(in srgb, var(--bengara) 55%, transparent);

  /* ---- Typography ---- */
  --font-display: "Shippori Mincho", "Hiragino Mincho ProN", "Yu Mincho", serif;
  --font-serif:   "Shippori Mincho", "Hiragino Mincho ProN", "Yu Mincho", serif;
  --font-serif-body: "Noto Serif JP", "Hiragino Mincho ProN", serif;
  --font-sans:    "Zen Kaku Gothic New", "Hiragino Kaku Gothic ProN", "Yu Gothic", system-ui, sans-serif;
  --font-body:    var(--font-sans);
  --font-mono:    "JetBrains Mono", "SFMono-Regular", ui-monospace, monospace;

  --text-xs:     12px;
  --text-sm:     13px;
  --text-base:   15px;
  --text-md:     16px;
  --text-lg:     18px;
  --text-xl:     22px;
  --text-2xl:    28px;
  --text-3xl:    36px;
  --text-4xl:    48px;
  --text-5xl:    64px;
  --text-display:88px;

  --weight-regular:  400;
  --weight-medium:   500;
  --weight-semibold: 600;
  --weight-bold:     700;

  --leading-none:    1;
  --leading-tight:   1.3;
  --leading-snug:    1.5;
  --leading-body:    1.85;
  --leading-relaxed: 2.05;

  --tracking-tight:  -0.01em;
  --tracking-normal:  0.02em;
  --tracking-wide:    0.08em;
  --tracking-wider:   0.18em;
  --tracking-widest:  0.28em;

  /* ---- Spacing / radii / layout ---- */
  --space-0:  0;
  --space-1:  4px;
  --space-2:  8px;
  --space-3:  12px;
  --space-4:  16px;
  --space-5:  20px;
  --space-6:  24px;
  --space-8:  32px;
  --space-10: 40px;
  --space-12: 48px;
  --space-16: 64px;
  --space-20: 80px;
  --space-24: 96px;
  --space-32: 128px;

  --radius-none: 0;
  --radius-xs:   2px;
  --radius-sm:   3px;
  --radius-md:   5px;
  --radius-lg:   8px;
  --radius-xl:   12px;
  --radius-hanko:4px;
  --radius-pill: 999px;

  --border-width:       1px;
  --border-width-thick: 2px;

  --container-sm:  640px;
  --container-md:  860px;
  --container-lg:  1080px;
  --container-xl:  1280px;
  --gutter:        var(--space-6);

  /* ---- Elevation ---- */
  --shadow-xs:   0 1px 2px rgba(31, 27, 22, 0.06);
  --shadow-sm:   0 2px 6px -1px rgba(31, 27, 22, 0.10);
  --shadow-md:   0 8px 24px -10px rgba(31, 27, 22, 0.18);
  --shadow-lg:   0 20px 50px -24px rgba(31, 27, 22, 0.30);
  --shadow-xl:   0 32px 70px -28px rgba(31, 27, 22, 0.38);
  --shadow-inset:inset 0 1px 2px rgba(31, 27, 22, 0.08);
  --ring-hairline: 0 0 0 1px var(--border-default);

  /* ---- Motion ---- */
  --duration-instant: 80ms;
  --duration-fast:    120ms;
  --duration-base:    200ms;
  --duration-slow:    320ms;
  --duration-slower:  480ms;
  --ease-standard: cubic-bezier(0.4, 0, 0.2, 1);
  --ease-out:      cubic-bezier(0.16, 1, 0.3, 1);
  --ease-in:       cubic-bezier(0.4, 0, 1, 1);
}

/* ---- Base / preflight ----------------------------------------------------- */
*, *::before, *::after { box-sizing: border-box; }

html { scroll-behavior: smooth; scroll-padding-top: 92px; }

body {
  margin: 0;
  font-family: var(--font-body);
  font-size: var(--text-base);
  line-height: var(--leading-body);
  letter-spacing: var(--tracking-normal);
  color: var(--text-primary);
  background-color: var(--surface-page);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

h1, h2, h3, h4, h5 {
  font-family: var(--font-display);
  font-weight: var(--weight-semibold);
  line-height: var(--leading-tight);
  letter-spacing: var(--tracking-normal);
  color: var(--text-primary);
  margin: 0;
}

p { margin: 0; text-wrap: pretty; }
a { color: var(--text-accent); text-decoration: none; }
a:hover { color: var(--accent-hover); }
img, svg { max-width: 100%; }
code, pre, kbd { font-family: var(--font-mono); }
::selection { background: var(--bengara-tint); color: var(--sumi-0); }
:focus-visible { outline: var(--border-width-thick) solid var(--focus-ring); outline-offset: 2px; }

/* 和紙のグレイン（全面に薄く敷く） */
.page-grain {
  position: fixed; inset: 0; pointer-events: none; z-index: 1;
  mix-blend-mode: multiply; opacity: .05;
  background-image: url("assets/washi-texture.svg"); background-size: 220px;
}

/* スキップリンク */
.skip-link {
  position: absolute; left: -999px; top: 0; z-index: 100;
  background: var(--sumi-0); color: var(--paper-0);
  padding: var(--space-3) var(--space-5); border-radius: var(--radius-sm);
}
.skip-link:focus { left: var(--space-4); top: var(--space-4); color: var(--paper-0); }

/* ==========================================================================
   コンポーネント（デザインシステムの再現）
   ========================================================================== */

/* ---- Logo ---- */
.ikk-logo{ display:inline-flex; align-items:center; gap:var(--space-3); color:var(--text-primary); user-select:none; line-height:1; }
.ikk-logo__seal{
  flex:none; display:flex; align-items:center; justify-content:center;
  font-family:var(--font-display); font-weight:var(--weight-semibold); color:var(--paper-0);
  background:var(--hi); border-radius:var(--radius-hanko);
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--paper-0) 22%, transparent);
}
.ikk-logo__wm{ display:flex; flex-direction:column; }
.ikk-logo__kanji{ font-family:var(--font-display); font-weight:var(--weight-semibold); letter-spacing:0.08em; color:inherit; }
.ikk-logo__romaji{ font-family:var(--font-sans); letter-spacing:0.42em; text-transform:uppercase; color:var(--text-tertiary); margin-top:0.55em; padding-left:0.1em; }
.ikk-logo--sm .ikk-logo__seal{ width:30px; height:30px; font-size:17px; }
.ikk-logo--sm .ikk-logo__kanji{ font-size:21px; }
.ikk-logo--sm .ikk-logo__romaji{ font-size:8.5px; }
.ikk-logo--md .ikk-logo__seal{ width:44px; height:44px; font-size:24px; }
.ikk-logo--md .ikk-logo__kanji{ font-size:30px; }
.ikk-logo--md .ikk-logo__romaji{ font-size:10.5px; }
.ikk-logo--inverse{ color:var(--paper-0); }
.ikk-logo--inverse .ikk-logo__romaji{ color:var(--nezumi-2); }

/* ---- Button ---- */
.ikk-btn{
  --_bg: var(--sumi-0); --_fg: var(--paper-0); --_bd: transparent; --_bgh: var(--sumi-1);
  display:inline-flex; align-items:center; justify-content:center; gap:var(--space-2);
  font-family:var(--font-sans); font-weight:var(--weight-medium);
  letter-spacing:var(--tracking-wide); line-height:1; white-space:nowrap;
  border:var(--border-width) solid var(--_bd); border-radius:var(--radius-sm);
  background:var(--_bg); color:var(--_fg); cursor:pointer;
  transition: background var(--duration-fast) var(--ease-standard),
              color var(--duration-fast) var(--ease-standard),
              transform var(--duration-fast) var(--ease-standard),
              border-color var(--duration-fast) var(--ease-standard);
}
.ikk-btn:hover{ background:var(--_bgh); color:var(--_fg); }
.ikk-btn:active{ transform: translateY(0.5px); }
.ikk-btn:focus-visible{ outline:var(--border-width-thick) solid var(--focus-ring); outline-offset:2px; }
.ikk-btn[disabled]{ opacity:0.45; cursor:not-allowed; transform:none; }
.ikk-btn--sm{ font-size:var(--text-sm); padding:8px 14px; }
.ikk-btn--md{ font-size:var(--text-base); padding:11px 20px; }
.ikk-btn--lg{ font-size:var(--text-lg); padding:14px 28px; }
.ikk-btn--block{ display:flex; width:100%; }
.ikk-btn--primary{ --_bg:var(--sumi-0); --_fg:var(--paper-0); --_bgh:var(--sumi-1); }
.ikk-btn--accent{ --_bg:var(--bengara); --_fg:var(--paper-0); --_bgh:var(--bengara-dark); }
.ikk-btn--secondary{ --_bg:var(--paper-0); --_fg:var(--sumi-0); --_bd:var(--sumi-line); --_bgh:var(--paper-2); }
.ikk-btn--ghost{ --_bg:transparent; --_fg:var(--sumi-0); --_bgh:var(--paper-2); }
.ikk-btn__icon{ display:inline-flex; }
.ikk-btn__icon svg{ display:block; width:1.05em; height:1.05em; }

/* ---- Card ---- */
.ikk-card{
  background:var(--surface-card); border:var(--border-width) solid var(--border-subtle);
  border-radius:var(--radius-md); color:var(--text-primary);
  transition: box-shadow var(--duration-base) var(--ease-standard),
              border-color var(--duration-base) var(--ease-standard),
              transform var(--duration-base) var(--ease-standard);
}
.ikk-card--flat{ box-shadow:none; }
.ikk-card--raised{ box-shadow:var(--shadow-md); border-color:transparent; }
.ikk-card--outline{ box-shadow:none; border-color:var(--border-default); }
.ikk-card--interactive{ cursor:pointer; }
.ikk-card--interactive:hover{ box-shadow:var(--shadow-lg); transform:translateY(-2px); }
.ikk-card--pad-sm{ padding:var(--space-4); }
.ikk-card--pad-md{ padding:var(--space-6); }
.ikk-card--pad-lg{ padding:var(--space-8); }

/* ---- SectionLabel（見出しの上のキッカー） ---- */
.ikk-seclabel{ display:inline-flex; align-items:center; gap:var(--space-3); font-family:var(--font-sans); }
.ikk-seclabel__rule{ width:24px; height:2px; background:var(--bengara); }
.ikk-seclabel__text{ font-size:var(--text-xs); font-weight:var(--weight-medium); letter-spacing:var(--tracking-widest); text-transform:uppercase; color:var(--text-secondary); }
.ikk-seclabel--center{ justify-content:center; }

/* ---- Badge ---- */
.ikk-badge{
  --_bg:var(--paper-2); --_fg:var(--nezumi); --_bd:transparent;
  display:inline-flex; align-items:center; gap:6px; font-family:var(--font-sans);
  font-size:var(--text-xs); font-weight:var(--weight-medium); line-height:1;
  letter-spacing:var(--tracking-normal); padding:5px 9px;
  border-radius:var(--radius-xs); border:var(--border-width) solid var(--_bd);
  background:var(--_bg); color:var(--_fg); white-space:nowrap;
}
.ikk-badge--neutral{ --_bg:var(--paper-2); --_fg:var(--nezumi); }
.ikk-badge--accent{ --_bg:var(--bengara-tint); --_fg:var(--bengara-dark); }
.ikk-badge--success{ --_bg:var(--kokei-tint); --_fg:var(--kokei-dark); }
.ikk-badge--info{ --_bg:var(--ai-tint); --_fg:var(--ai-dark); }

/* ---- Tag ---- */
.ikk-tag{
  display:inline-flex; align-items:center; gap:6px; font-family:var(--font-sans);
  font-size:var(--text-sm); line-height:1; color:var(--text-strong);
  background:var(--paper-0); border:var(--border-width) solid var(--border-default);
  border-radius:var(--radius-pill); padding:6px 12px; white-space:nowrap;
}
.ikk-tag--muted{ background:var(--paper-2); border-color:transparent; color:var(--nezumi); }

/* ---- Hanko（落款） ---- */
.ikk-hanko{
  display:inline-flex; align-items:center; justify-content:center; flex:none;
  font-family:var(--font-display); font-weight:var(--weight-semibold);
  color:var(--paper-0); background:var(--hi); line-height:1; letter-spacing:0;
  border-radius:var(--radius-hanko);
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--paper-0) 22%, transparent);
}
.ikk-hanko--outline{ background:transparent; color:var(--hi); box-shadow: inset 0 0 0 2px var(--hi); }
.ikk-hanko--on-ink{ color:var(--paper-0); box-shadow: inset 0 0 0 2px var(--paper-0); }
.ikk-hanko--lg{ width:56px; height:56px; font-size:30px; }

/* ---- Tabs ---- */
.ikk-tabs{ display:inline-flex; gap:var(--space-6); border-bottom:var(--border-width) solid var(--border-default); }
.ikk-tab{
  position:relative; appearance:none; border:none; background:transparent; cursor:pointer;
  font-family:var(--font-sans); font-size:var(--text-base); font-weight:var(--weight-medium);
  color:var(--text-tertiary); padding:0 0 var(--space-3); letter-spacing:var(--tracking-normal);
  transition: color var(--duration-fast) var(--ease-standard);
}
.ikk-tab::after{
  content:""; position:absolute; left:0; right:0; bottom:-1px; height:2px;
  background:var(--bengara); transform:scaleX(0); transform-origin:center;
  transition: transform var(--duration-base) var(--ease-out);
}
.ikk-tab:hover{ color:var(--text-secondary); }
.ikk-tab--active{ color:var(--text-primary); }
.ikk-tab--active::after{ transform:scaleX(1); }
.ikk-tab:focus-visible{ outline:var(--border-width-thick) solid var(--focus-ring); outline-offset:3px; border-radius:var(--radius-xs); }

/* ==========================================================================
   レイアウト & ページ固有
   ========================================================================== */
.wrap { max-width: 1180px; margin: 0 auto; padding: 0 var(--space-8); position: relative; }
section { position: relative; }

/* ---- header ---- */
.hdr { position: sticky; top: 0; z-index: 50; background: color-mix(in srgb, var(--paper-1) 88%, transparent); backdrop-filter: blur(8px); border-bottom: 1px solid var(--border-subtle); }
.hdr__row { display: flex; align-items: center; justify-content: space-between; height: 76px; }
.nav { display: flex; align-items: center; gap: var(--space-8); }
.nav a { font-family: var(--font-sans); font-size: var(--text-base); color: var(--text-secondary); letter-spacing: var(--tracking-normal); transition: color var(--duration-fast) var(--ease-standard); }
.nav a:hover { color: var(--text-primary); }
.hdr__cta { display: flex; align-items: center; gap: var(--space-4); }
.nav-toggle { display: none; appearance: none; border: 1px solid var(--border-default); background: var(--paper-0); border-radius: var(--radius-sm); padding: 8px; cursor: pointer; color: var(--text-primary); }
.nav-toggle svg { display: block; width: 22px; height: 22px; }

/* ---- hero ---- */
.hero { overflow: hidden; }
.hero__grid { display: grid; grid-template-columns: 1.35fr 1fr; gap: var(--space-16); align-items: center; padding: var(--space-24) 0 var(--space-20); }
.hero h1 { font-size: clamp(40px, 5vw, 64px); line-height: 1.32; letter-spacing: 0.04em; font-weight: var(--weight-semibold); margin-top: var(--space-5); }
.hero__lede { font-family: var(--font-sans); font-size: var(--text-lg); line-height: var(--leading-body); color: var(--text-secondary); max-width: 30em; margin-top: var(--space-6); }
.hero__actions { display: flex; gap: var(--space-4); margin-top: var(--space-8); flex-wrap: wrap; }
.hero__seal { display: flex; align-items: center; justify-content: center; }
.hero__vert { writing-mode: vertical-rl; font-family: var(--font-display); font-weight: var(--weight-medium); font-size: clamp(30px, 3.6vw, 46px); line-height: 1.9; letter-spacing: 0.18em; color: var(--text-primary); height: 380px; border-right: 1px solid var(--sumi-line); padding-right: var(--space-6); }
.hero__vert .accent { color: var(--bengara); }

/* ---- generic section heads ---- */
.shead { text-align: center; display: flex; flex-direction: column; align-items: center; gap: var(--space-4); margin-bottom: var(--space-12); }
.shead h2 { font-size: var(--text-3xl); letter-spacing: 0.04em; }
.shead p { font-family: var(--font-sans); color: var(--text-secondary); font-size: var(--text-base); }
.pad { padding: var(--space-24) 0; }
.pad-sm { padding: var(--space-20) 0; }

/* ---- services ---- */
.svc { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-6); }
.svc__ico { width: 48px; height: 48px; border-radius: var(--radius-md); background: var(--bengara-tint); color: var(--bengara-dark); display: flex; align-items: center; justify-content: center; margin-bottom: var(--space-5); }
.svc__ico svg { width: 24px; height: 24px; }
.svc h3 { font-size: var(--text-xl); margin-bottom: var(--space-3); }
.svc p { font-family: var(--font-sans); color: var(--text-secondary); font-size: var(--text-base); line-height: var(--leading-body); margin-bottom: var(--space-5); }
.svc__link { display: inline-flex; align-items: center; gap: 6px; font-family: var(--font-sans); font-size: var(--text-sm); font-weight: var(--weight-medium); color: var(--bengara); letter-spacing: var(--tracking-wide); }
.svc__link svg { width: 15px; height: 15px; }

/* ---- work ---- */
.work { background: var(--paper-2); }
.work__tabs { display: flex; justify-content: center; margin-bottom: var(--space-10); }
.work__grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--space-6); }
.proj { display: flex; flex-direction: column; gap: var(--space-4); }
.proj__top { display: flex; align-items: center; justify-content: space-between; }
.proj__client { font-family: var(--font-sans); font-size: var(--text-xs); color: var(--text-tertiary); letter-spacing: var(--tracking-wide); }
.proj h3 { font-size: var(--text-xl); line-height: 1.5; }
.proj p { font-family: var(--font-sans); font-size: var(--text-sm); color: var(--text-secondary); line-height: var(--leading-body); }
.proj__tags { display: flex; flex-wrap: wrap; gap: var(--space-2); margin-top: auto; padding-top: var(--space-2); }
.proj[hidden] { display: none; }

/* ---- process ---- */
.steps { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--space-8); }
.step__no { font-family: var(--font-display); font-size: var(--text-4xl); font-weight: var(--weight-semibold); color: var(--bengara); line-height: 1; }
.step__bar { height: 1px; background: var(--border-strong); margin: var(--space-4) 0 var(--space-5); }
.step h3 { font-size: var(--text-lg); margin-bottom: var(--space-3); }
.step p { font-family: var(--font-sans); font-size: var(--text-sm); color: var(--text-secondary); line-height: var(--leading-body); }

/* ---- company（会社概要） ---- */
.company { background: var(--paper-1); }
.company__table { max-width: var(--container-md); margin: 0 auto; border-top: 1px solid var(--border-default); }
.company__row { display: grid; grid-template-columns: 200px 1fr; gap: var(--space-6); padding: var(--space-5) var(--space-2); border-bottom: 1px solid var(--border-subtle); }
.company__row dt { font-family: var(--font-sans); font-size: var(--text-sm); font-weight: var(--weight-medium); color: var(--text-secondary); letter-spacing: var(--tracking-wide); margin: 0; }
.company__row dd { font-family: var(--font-sans); font-size: var(--text-base); color: var(--text-primary); margin: 0; line-height: var(--leading-body); }
.todo { color: var(--text-tertiary); font-size: var(--text-xs); font-family: var(--font-mono); }

/* ---- contact CTA ---- */
.cta { background: var(--sumi-0); color: var(--paper-0); }
.cta__grain::before { content:""; position:absolute; inset:0; pointer-events:none; mix-blend-mode:overlay; opacity:.06; background-image:url("assets/washi-texture.svg"); background-size:220px; }
.cta__inner { text-align: center; display: flex; flex-direction: column; align-items: center; gap: var(--space-6); position: relative; }
.cta h2 { color: var(--paper-0); font-size: var(--text-3xl); line-height: 1.5; letter-spacing: 0.04em; }
.cta p { font-family: var(--font-sans); color: color-mix(in srgb, var(--paper-0) 74%, transparent); font-size: var(--text-base); max-width: 36em; }
.cta__mail { font-family: var(--font-mono); font-size: var(--text-base); color: var(--paper-0); letter-spacing: var(--tracking-wide); border-bottom: 1px solid color-mix(in srgb, var(--paper-0) 40%, transparent); padding-bottom: 2px; }
.cta__mail:hover { color: var(--bengara-soft); }

/* ---- footer ---- */
.ftr { border-top: 1px solid var(--border-default); }
.ftr__row { display: flex; justify-content: space-between; align-items: flex-start; padding: var(--space-16) 0 var(--space-10); gap: var(--space-12); }
.ftr__brand { max-width: 320px; display: flex; flex-direction: column; gap: var(--space-4); }
.ftr__brand p { font-family: var(--font-sans); font-size: var(--text-sm); color: var(--text-secondary); line-height: 1.8; }
.ftr__links { display: flex; gap: var(--space-16); }
.ftr__col { display: flex; flex-direction: column; gap: var(--space-3); }
.ftr__col h4 { font-family: var(--font-sans); font-size: var(--text-xs); letter-spacing: var(--tracking-wider); text-transform: uppercase; color: var(--text-tertiary); margin-bottom: var(--space-2); }
.ftr__col a { font-family: var(--font-sans); font-size: var(--text-sm); color: var(--text-secondary); }
.ftr__col a:hover { color: var(--text-primary); }
.ftr__legal { display: flex; justify-content: space-between; padding: var(--space-6) 0; border-top: 1px solid var(--border-subtle); font-family: var(--font-mono); font-size: var(--text-xs); color: var(--text-tertiary); gap: var(--space-4); flex-wrap: wrap; }

/* ==========================================================================
   スクロール時のフェードイン（控えめ・墨が紙に沈むように）
   ========================================================================== */
.reveal { opacity: 0; transform: translateY(14px); transition: opacity var(--duration-slower) var(--ease-out), transform var(--duration-slower) var(--ease-out); }
.reveal.is-visible { opacity: 1; transform: none; }

/* ==========================================================================
   レスポンシブ
   ========================================================================== */
@media (max-width: 900px) {
  .hero__grid, .svc, .work__grid, .steps { grid-template-columns: 1fr; }
  .hero__aside { display: none; }
  .nav, .hdr__cta { display: none; }
  .nav-toggle { display: inline-flex; }
  .hdr.is-open .nav {
    display: flex; position: absolute; top: 76px; left: 0; right: 0;
    flex-direction: column; align-items: flex-start; gap: var(--space-5);
    background: var(--paper-0); border-bottom: 1px solid var(--border-default);
    padding: var(--space-6) var(--space-8); box-shadow: var(--shadow-md);
  }
  .company__row { grid-template-columns: 1fr; gap: var(--space-1); }
  .ftr__row { flex-direction: column; gap: var(--space-10); }
  .ftr__links { gap: var(--space-10); flex-wrap: wrap; }
}

@media (max-width: 600px) {
  .wrap { padding: 0 var(--space-5); }
  .pad { padding: var(--space-16) 0; }
}

/* モーション抑制設定の尊重 */
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after { animation-duration: 0.001ms !important; transition-duration: 0.001ms !important; }
  .reveal { opacity: 1; transform: none; }
}
