@charset "UTF-8";
html {
  overflow-x: hidden;
}

body {
  font-family: "Noto Sans JP", sans-serif;
  background-color: #faf9f7;
  color: #000;
  font-weight: 200;
}

.font-serif {
  font-family: "Noto Serif JP", serif;
}

.wf-canvas {
  width: 100%;
  background: #faf9f7;
  min-height: 100vh;
}

/* 初期ロゴ（アクセス時のみ表示） */
#initial-logo {
  transition: opacity 0.65s ease, visibility 0.65s ease;
}

#initial-logo.is-hidden {
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
}

/* ヘッダー：オープニング後、降下して表示 */
#site-header {
  transition: transform 0.55s cubic-bezier(0.2, 0.8, 0.2, 1), opacity 0.45s ease;
}

#site-header.header-pending {
  transform: translateY(-100%);
  opacity: 0;
  pointer-events: none;
}

/* ハンバーガーメニュー */
#menu-overlay {
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.4s ease, visibility 0.4s;
}

#menu-overlay.is-open {
  opacity: 1;
  visibility: visible;
}

.menu-item {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity 0.6s cubic-bezier(0.2, 0.8, 0.2, 1), transform 0.6s cubic-bezier(0.2, 0.8, 0.2, 1);
}

#menu-overlay.is-open .menu-item {
  opacity: 1;
  transform: translateY(0);
}

#menu-overlay.is-open .menu-item:nth-child(1) {
  transition-delay: 0.1s;
}

#menu-overlay.is-open .menu-item:nth-child(2) {
  transition-delay: 0.18s;
}

#menu-overlay.is-open .menu-item:nth-child(3) {
  transition-delay: 0.26s;
}

#menu-overlay.is-open .menu-item:nth-child(4) {
  transition-delay: 0.34s;
}

#menu-overlay.is-open .menu-item:nth-child(5) {
  transition-delay: 0.42s;
}

#menu-overlay.is-open .menu-item:nth-child(6) {
  transition-delay: 0.5s;
}

body {
  font-family: "Noto Sans JP", sans-serif;
  background-color: #fff;
  color: #000;
  font-weight: 200;
}

.font-serif {
  font-family: "Noto Serif JP", serif;
}

.wf-canvas {
  width: 100%;
  background: white;
  min-height: 100vh;
}

.wf-img {
  background-color: #e5e7eb;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  color: #6b7280;
  text-align: center;
  padding: 1rem;
}

.char-wrap {
  display: inline-block;
}

.char {
  display: inline-block;
  opacity: 0;
  filter: blur(8px);
  transform: translateY(10px);
  transition: opacity 1.5s ease-out, filter 1.5s ease-out, transform 1.5s cubic-bezier(0.2, 0.8, 0.2, 1);
}

.is-visible .char {
  opacity: 1;
  filter: blur(0);
  transform: translateY(0);
}

.split-text-fast .char {
  transition: opacity 0.5s ease-out, filter 0.5s ease-out, transform 0.5s cubic-bezier(0.2, 0.8, 0.2, 1);
}

.img-reveal {
  opacity: 0;
  transform: scale(1.1);
  transition: opacity 1.5s ease-out, transform 1.5s cubic-bezier(0.16, 1, 0.3, 1);
}

.img-reveal.is-visible {
  opacity: 1;
  transform: scale(1);
}

#menu-overlay {
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.4s ease, visibility 0.4s;
}

#menu-overlay.is-open {
  opacity: 1;
  visibility: visible;
}

.menu-item {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity 0.6s cubic-bezier(0.2, 0.8, 0.2, 1), transform 0.6s cubic-bezier(0.2, 0.8, 0.2, 1);
}

#menu-overlay.is-open .menu-item {
  opacity: 1;
  transform: translateY(0);
}

#menu-overlay.is-open .menu-item:nth-child(1) {
  transition-delay: 0.1s;
}

#menu-overlay.is-open .menu-item:nth-child(2) {
  transition-delay: 0.18s;
}

#menu-overlay.is-open .menu-item:nth-child(3) {
  transition-delay: 0.26s;
}

#menu-overlay.is-open .menu-item:nth-child(4) {
  transition-delay: 0.34s;
}

#menu-overlay.is-open .menu-item:nth-child(5) {
  transition-delay: 0.42s;
}

#menu-overlay.is-open .menu-item:nth-child(6) {
  transition-delay: 0.5s;
}

body {
  font-family: "Noto Sans JP", sans-serif;
  background-color: #fff;
  color: #000;
  font-weight: 200;
}

.font-serif {
  font-family: "Noto Serif JP", serif;
}

.wf-canvas {
  width: 100%;
  background: white;
  min-height: 100vh;
}

.wf-img {
  background-color: #e5e7eb;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  color: #6b7280;
  text-align: center;
  padding: 1rem;
}

.char-wrap {
  display: inline-block;
}

.char {
  display: inline-block;
  opacity: 0;
  filter: blur(8px);
  transform: translateY(10px);
  transition: opacity 1.5s ease-out, filter 1.5s ease-out, transform 1.5s cubic-bezier(0.2, 0.8, 0.2, 1);
}

.is-visible .char {
  opacity: 1;
  filter: blur(0);
  transform: translateY(0);
}

.split-text-fast .char {
  transition: opacity 0.5s ease-out, filter 0.5s ease-out, transform 0.5s cubic-bezier(0.2, 0.8, 0.2, 1);
}

.img-reveal {
  opacity: 0;
  transform: scale(1.1);
  transition: opacity 1.5s ease-out, transform 1.5s cubic-bezier(0.16, 1, 0.3, 1);
}

.img-reveal.is-visible {
  opacity: 1;
  transform: scale(1);
}

#menu-overlay {
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.4s ease, visibility 0.4s;
}

#menu-overlay.is-open {
  opacity: 1;
  visibility: visible;
}

.menu-item {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity 0.6s cubic-bezier(0.2, 0.8, 0.2, 1), transform 0.6s cubic-bezier(0.2, 0.8, 0.2, 1);
}

#menu-overlay.is-open .menu-item {
  opacity: 1;
  transform: translateY(0);
}

#menu-overlay.is-open .menu-item:nth-child(1) {
  transition-delay: 0.1s;
}

#menu-overlay.is-open .menu-item:nth-child(2) {
  transition-delay: 0.18s;
}

#menu-overlay.is-open .menu-item:nth-child(3) {
  transition-delay: 0.26s;
}

#menu-overlay.is-open .menu-item:nth-child(4) {
  transition-delay: 0.34s;
}

#menu-overlay.is-open .menu-item:nth-child(5) {
  transition-delay: 0.42s;
}

#menu-overlay.is-open .menu-item:nth-child(6) {
  transition-delay: 0.5s;
}

.business-tag {
  display: inline-block;
  padding: 0.5rem 1rem;
  background-color: #f3f4f6;
  border-radius: 9999px;
  font-size: 0.75rem;
  color: #374151;
}

.business-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem 0.75rem;
}

body {
  font-family: "Noto Sans JP", sans-serif;
  background-color: #fff;
  color: #000;
  font-weight: 200;
}

.font-serif {
  font-family: "Noto Serif JP", serif;
}

.wf-canvas {
  width: 100%;
  background: white;
  min-height: 100vh;
}

.char-wrap {
  display: inline-block;
}

.char {
  display: inline-block;
  opacity: 0;
  filter: blur(8px);
  transform: translateY(10px);
  transition: opacity 1.5s ease-out, filter 1.5s ease-out, transform 1.5s cubic-bezier(0.2, 0.8, 0.2, 1);
}

.is-visible .char {
  opacity: 1;
  filter: blur(0);
  transform: translateY(0);
}

.split-text-fast .char {
  transition: opacity 0.5s ease-out, filter 0.5s ease-out, transform 0.5s cubic-bezier(0.2, 0.8, 0.2, 1);
}

#menu-overlay {
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.4s ease, visibility 0.4s;
}

#menu-overlay.is-open {
  opacity: 1;
  visibility: visible;
}

.menu-item {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity 0.6s cubic-bezier(0.2, 0.8, 0.2, 1), transform 0.6s cubic-bezier(0.2, 0.8, 0.2, 1);
}

#menu-overlay.is-open .menu-item {
  opacity: 1;
  transform: translateY(0);
}

#menu-overlay.is-open .menu-item:nth-child(1) {
  transition-delay: 0.1s;
}

#menu-overlay.is-open .menu-item:nth-child(2) {
  transition-delay: 0.18s;
}

#menu-overlay.is-open .menu-item:nth-child(3) {
  transition-delay: 0.26s;
}

#menu-overlay.is-open .menu-item:nth-child(4) {
  transition-delay: 0.34s;
}

#menu-overlay.is-open .menu-item:nth-child(5) {
  transition-delay: 0.42s;
}

#menu-overlay.is-open .menu-item:nth-child(6) {
  transition-delay: 0.5s;
}

input:focus, select:focus, textarea:focus {
  outline: none;
  border-color: #1e3a8a;
}

html {
  overflow-x: hidden;
}

body {
  font-family: "Noto Sans JP", sans-serif;
  background-color: #faf9f7;
  color: #000;
  font-weight: 200;
}

.font-serif {
  font-family: "Noto Serif JP", serif;
}

.wf-canvas {
  width: 100%;
  background: white;
  min-height: 100vh;
}

/* 画面幅100%で表示（メインビジュアル・BE HAPPY・フッターなど） */
.full-bleed {
  width: 100vw;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
  max-width: none;
}

/* メインビジュアル：画面幅ぴったり・画像が右端まで切れずに表示（デモ用複数セクション対応） */
.fv-demo-section .fv-inner {
  width: 100vw !important;
  min-width: 100vw;
  box-sizing: border-box;
}

.fv-demo-section .fv-img-layer {
  width: 100vw !important;
  min-width: 100vw;
  left: 50% !important;
  right: auto !important;
  margin-left: -50vw !important;
  top: 0 !important;
  bottom: 0 !important;
  height: 100% !important;
  background-size: cover !important;
  background-position: center center !important;
}

/* wf-img のグレー背景とテキストを無効化 */
.wf-img {
  background-color: transparent; /* 背景色を消す */
  display: block; /* 中身の画像だけを見せる */
  padding: 0;
  color: transparent; /* 万が一テキストが残っても見えないように */
}

/* C.html 移植: 文字が1文字ずつ浮かび上がる */
.char-wrap {
  display: inline-block;
}

.char {
  display: inline-block;
  opacity: 0;
  filter: blur(8px);
  transform: translateY(10px);
  transition: opacity 1.5s ease-out, filter 1.5s ease-out, transform 1.5s cubic-bezier(0.2, 0.8, 0.2, 1);
}

.is-visible .char {
  opacity: 1;
  filter: blur(0);
  transform: translateY(0);
}

/* Business Fields 以下: 3倍速用 */
.split-text-fast .char {
  transition: opacity 0.5s ease-out, filter 0.5s ease-out, transform 0.5s cubic-bezier(0.2, 0.8, 0.2, 1);
}

/* About Us 用: ブロック単位フェードアップ */
.block-reveal {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.6s ease-out, transform 0.6s ease-out;
}

.block-reveal.is-visible {
  opacity: 1;
  transform: translateY(0);
}

/* C.html 移植: 青い下線が引かれる highlight-text */
.highlight-text {
  position: relative;
  display: inline-block;
  color: #000;
}

.highlight-text::after {
  content: "";
  position: absolute;
  bottom: 0px;
  left: 0;
  width: 0;
  height: 1px;
  background-color: #2563eb;
  transition: width 1.5s cubic-bezier(0.16, 1, 0.3, 1);
  transition-delay: 2s;
}

.is-visible .highlight-text::after {
  width: 100%;
}

.is-visible .highlight-text {
  animation: text-focus-glow 2.5s ease-out forwards;
  animation-delay: 1.8s;
}

@keyframes text-focus-glow {
  0% {
    color: #000;
    text-shadow: none;
  }
  40% {
    color: #2563eb;
    text-shadow: 0 0 20px rgba(37, 99, 235, 0.5);
  }
  100% {
    color: #1e3a8a;
    text-shadow: 0 0 15px rgba(37, 99, 235, 0.15);
  }
}
/* BUSINESS カード: スクロールで下からふわっとスタッガー表示 */
.business-card {
  opacity: 0;
  transform: translateY(32px) scale(0.98);
  transition: opacity 0.7s cubic-bezier(0.22, 1, 0.36, 1), transform 0.7s cubic-bezier(0.22, 1, 0.36, 1);
}

#business-section.observe-target.is-visible .business-card {
  opacity: 1;
  transform: translateY(0) scale(1);
}

#business-section.observe-target.is-visible .business-cards-grid .business-card:nth-child(1) {
  transition-delay: 0.05s;
}

#business-section.observe-target.is-visible .business-cards-grid .business-card:nth-child(2) {
  transition-delay: 0.14s;
}

#business-section.observe-target.is-visible .business-cards-grid .business-card:nth-child(3) {
  transition-delay: 0.23s;
}

#business-section.observe-target.is-visible .business-cards-grid .business-card:nth-child(4) {
  transition-delay: 0.32s;
}

#business-section.observe-target.is-visible .business-cards-grid .business-card:nth-child(5) {
  transition-delay: 0.41s;
}

#business-section.observe-target.is-visible .business-cards-grid .business-card:nth-child(6) {
  transition-delay: 0.5s;
}

/* C.html 移植: 画像がふわっと現れる img-reveal */
.img-reveal {
  opacity: 0;
  transform: scale(1.1);
  transition: opacity 1.5s ease-out, transform 1.5s cubic-bezier(0.16, 1, 0.3, 1);
}

.img-reveal.is-visible {
  opacity: 1;
  transform: scale(1);
}

/* VISION2: 文字の速度に合わせてゆっくり1枚ずつ浮かび上がる */
.vision2-reveal {
  opacity: 0;
  transform: scale(1.05) translateY(10px);
  transition: opacity 2.2s ease-out, transform 2.2s cubic-bezier(0.16, 1, 0.3, 1);
}

.vision2-reveal.is-visible {
  opacity: 1;
  transform: scale(1) translateY(0);
}

/* VISION Scene 2: スクロールで上から1枚ずつ表示→ランダム切替（文字より先に動く） */
.vision-slot {
  opacity: 0;
  transform: translateY(12px);
  transition: opacity 0.8s ease-out, transform 0.8s ease-out;
}

.vision-collage-visible .vision-slot {
  opacity: 1;
  transform: translateY(0);
}

.vision-slot-item {
  opacity: 0;
  transition: opacity 0.6s ease-in-out;
}

.vision-slot-item.active {
  opacity: 1;
}

/* B.html 移植: FV 用 stagger-container（行単位のフェード） */
.stagger-container .line {
  opacity: 0;
  transform: translateY(30px);
  transition: opacity 1.2s cubic-bezier(0.2, 0.8, 0.2, 1), transform 1.2s cubic-bezier(0.2, 0.8, 0.2, 1);
  display: block;
}

.stagger-container.is-visible .line {
  opacity: 1;
  transform: translateY(0);
}

.stagger-container.is-visible .line:nth-child(1) {
  transition-delay: 0.1s;
}

.stagger-container.is-visible .line:nth-child(2) {
  transition-delay: 0.3s;
}

.stagger-container.is-visible .line:nth-child(3) {
  transition-delay: 0.5s;
}

.stagger-container.is-visible .line:nth-child(4) {
  transition-delay: 0.7s;
}

/* ハンバーガーメニュー */
#menu-overlay {
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.4s ease, visibility 0.4s;
}

#menu-overlay.is-open {
  opacity: 1;
  visibility: visible;
}

.menu-item {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity 0.6s cubic-bezier(0.2, 0.8, 0.2, 1), transform 0.6s cubic-bezier(0.2, 0.8, 0.2, 1);
}

#menu-overlay.is-open .menu-item {
  opacity: 1;
  transform: translateY(0);
}

#menu-overlay.is-open .menu-item:nth-child(1) {
  transition-delay: 0.1s;
}

#menu-overlay.is-open .menu-item:nth-child(2) {
  transition-delay: 0.18s;
}

#menu-overlay.is-open .menu-item:nth-child(3) {
  transition-delay: 0.26s;
}

#menu-overlay.is-open .menu-item:nth-child(4) {
  transition-delay: 0.34s;
}

#menu-overlay.is-open .menu-item:nth-child(5) {
  transition-delay: 0.42s;
}

#menu-overlay.is-open .menu-item:nth-child(6) {
  transition-delay: 0.5s;
}

/* BE HAPPY: 波紋が広がるエフェクト（透明から素早く現れる） */
@keyframes ripple-expand {
  0% {
    transform: translate(-50%, -50%) scale(0.2);
    opacity: 0;
  }
  8% {
    transform: translate(-50%, -50%) scale(0.25);
    opacity: 0.15;
  }
  100% {
    transform: translate(-50%, -50%) scale(1.5);
    opacity: 0;
  }
}
.ripple-ring {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 400px;
  height: 400px;
  border: 1px solid rgba(255, 255, 255, 0.4);
  border-radius: 50%;
  animation: ripple-expand 8s ease-out infinite;
}

.ripple-ring:nth-child(1) {
  animation-delay: 0s;
}

.ripple-ring:nth-child(2) {
  animation-delay: 2s;
}

.ripple-ring:nth-child(3) {
  animation-delay: 4s;
}

.ripple-ring:nth-child(4) {
  animation-delay: 6s;
}

/* BE HAPPY 背景：温もり・循環（ノイズ/和紙・再生紙調） */
.behappy-bg-1 {
  background-color: #1c1d21;
  background-image: repeating-linear-gradient(90deg, transparent 0, transparent 1px, rgba(255, 255, 255, 0.012) 1px, rgba(255, 255, 255, 0.012) 2px), repeating-linear-gradient(0deg, transparent 0, transparent 1px, rgba(0, 0, 0, 0.02) 1px, rgba(0, 0, 0, 0.02) 2px), radial-gradient(ellipse 120% 80% at 50% 40%, rgba(45, 42, 38, 0.6) 0%, transparent 60%);
}

.behappy-bg-1 .behappy-overlay {
  background: rgba(0, 0, 0, 0.12);
}

.behappy-variant .behappy-overlay {
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 1;
}

.behappy-variant .behappy-content-wrap {
  position: relative;
  z-index: 2;
}

html {
  overflow-x: hidden;
}

body {
  font-family: "Noto Sans JP", sans-serif;
  background-color: #faf9f7;
  color: #000;
  font-weight: 200;
}

.font-serif {
  font-family: "Noto Serif JP", serif;
}

.wf-canvas {
  width: 100%;
  background: #faf9f7;
  min-height: 100vh;
}

#initial-logo {
  transition: opacity 0.65s ease, visibility 0.65s ease;
}

#initial-logo.is-hidden {
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
}

#site-header {
  transition: transform 0.55s cubic-bezier(0.2, 0.8, 0.2, 1), opacity 0.45s ease;
}

#site-header.header-pending {
  transform: translateY(-100%);
  opacity: 0;
  pointer-events: none;
}

#menu-overlay {
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.4s ease, visibility 0.4s;
}

#menu-overlay.is-open {
  opacity: 1;
  visibility: visible;
}

.menu-item {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity 0.6s cubic-bezier(0.2, 0.8, 0.2, 1), transform 0.6s cubic-bezier(0.2, 0.8, 0.2, 1);
}

#menu-overlay.is-open .menu-item {
  opacity: 1;
  transform: translateY(0);
}

#menu-overlay.is-open .menu-item:nth-child(1) {
  transition-delay: 0.1s;
}

#menu-overlay.is-open .menu-item:nth-child(2) {
  transition-delay: 0.18s;
}

#menu-overlay.is-open .menu-item:nth-child(3) {
  transition-delay: 0.26s;
}

#menu-overlay.is-open .menu-item:nth-child(4) {
  transition-delay: 0.34s;
}

#menu-overlay.is-open .menu-item:nth-child(5) {
  transition-delay: 0.42s;
}

#menu-overlay.is-open .menu-item:nth-child(6) {
  transition-delay: 0.5s;
}

.char-wrap {
  display: inline-block;
}

.char {
  display: inline-block;
  opacity: 0;
  filter: blur(8px);
  transform: translateY(10px);
  transition: opacity 1.5s ease-out, filter 1.5s ease-out, transform 1.5s cubic-bezier(0.2, 0.8, 0.2, 1);
}

.is-visible .char {
  opacity: 1;
  filter: blur(0);
  transform: translateY(0);
}

.split-text-fast .char {
  transition: opacity 0.5s ease-out, filter 0.5s ease-out, transform 0.5s cubic-bezier(0.2, 0.8, 0.2, 1);
}

html {
  overflow-x: hidden;
}

body {
  font-family: "Noto Sans JP", sans-serif;
  background-color: #fff;
  color: #000;
  font-weight: 200;
}

.font-serif {
  font-family: "Noto Serif JP", serif;
}

.wf-canvas {
  width: 100%;
  background: white;
  min-height: 100vh;
}

.full-bleed {
  width: 100vw;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
  max-width: none;
}

.wf-img {
  background-color: #e5e7eb;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  color: #6b7280;
  text-align: center;
  padding: 1rem;
}

.char-wrap {
  display: inline-block;
}

.char {
  display: inline-block;
  opacity: 0;
  filter: blur(8px);
  transform: translateY(10px);
  transition: opacity 1.5s ease-out, filter 1.5s ease-out, transform 1.5s cubic-bezier(0.2, 0.8, 0.2, 1);
}

.is-visible .char {
  opacity: 1;
  filter: blur(0);
  transform: translateY(0);
}

.split-text-fast .char {
  transition: opacity 0.5s ease-out, filter 0.5s ease-out, transform 0.5s cubic-bezier(0.2, 0.8, 0.2, 1);
}

.img-reveal {
  opacity: 0;
  transform: scale(1.1);
  transition: opacity 1.5s ease-out, transform 1.5s cubic-bezier(0.16, 1, 0.3, 1);
}

.img-reveal.is-visible {
  opacity: 1;
  transform: scale(1);
}

#menu-overlay {
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.4s ease, visibility 0.4s;
}

#menu-overlay.is-open {
  opacity: 1;
  visibility: visible;
}

.menu-item {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity 0.6s cubic-bezier(0.2, 0.8, 0.2, 1), transform 0.6s cubic-bezier(0.2, 0.8, 0.2, 1);
}

#menu-overlay.is-open .menu-item {
  opacity: 1;
  transform: translateY(0);
}

#menu-overlay.is-open .menu-item:nth-child(1) {
  transition-delay: 0.1s;
}

#menu-overlay.is-open .menu-item:nth-child(2) {
  transition-delay: 0.18s;
}

#menu-overlay.is-open .menu-item:nth-child(3) {
  transition-delay: 0.26s;
}

#menu-overlay.is-open .menu-item:nth-child(4) {
  transition-delay: 0.34s;
}

#menu-overlay.is-open .menu-item:nth-child(5) {
  transition-delay: 0.42s;
}

#menu-overlay.is-open .menu-item:nth-child(6) {
  transition-delay: 0.5s;
}

body {
  font-family: "Noto Sans JP", sans-serif;
  background-color: #faf9f7;
  color: #000;
  font-weight: 200;
}

.font-serif {
  font-family: "Noto Serif JP", serif;
}

.wf-canvas {
  width: 100%;
  background: #faf9f7;
  min-height: 100vh;
}

table th, table td {
  border: 1px solid #e5e7eb;
  padding: 14px 16px;
  vertical-align: top;
}

table th {
  width: 32%;
  background: #f8fafc;
  text-align: left;
  color: #374151;
  font-weight: 400;
}

body {
  font-family: "Noto Sans JP", sans-serif;
  background-color: #faf9f7;
  color: #000;
  font-weight: 200;
}

.font-serif {
  font-family: "Noto Serif JP", serif;
}

.wf-canvas {
  width: 100%;
  background: #faf9f7;
  min-height: 100vh;
}/*# sourceMappingURL=style.css.map */