/* =============================================================
   Bull Tail Works — Writing LP page layout
   tokens.css / components.css に依存。このLP固有のレイアウトのみ定義。
   値はデザインプロトタイプ（_design/writing/project/index.html）に忠実。
   ============================================================= */

/* ---------- GTM noscript ---------- */
.gtm-noscript { display: none; visibility: hidden; } /* GTM noscript iframe を非表示（標準スニペットの inline style を置換）*/

/* ---------- Header ---------- */
.site-header {
  position: sticky; top: 0; z-index: 50;
  background: rgba(255,255,255,.92); /* frosted glass — intentional non-token value */
  -webkit-backdrop-filter: saturate(120%) blur(8px); /* iOS Safari 旧版はプレフィックス必須 */
  backdrop-filter: saturate(120%) blur(8px);
  border-bottom: 1px solid var(--color-border-soft);
  transition: box-shadow var(--dur) var(--ease);
}
.site-header.is-scrolled { box-shadow: var(--shadow-xs); }
.site-header__inner {
  display: flex; align-items: center; justify-content: space-between;
  height: 76px; /* 76px: ヘッダー高さ。space-16(64) と space-20(80) の中間 by design */
}
.brand { display: flex; flex-direction: column; line-height: 1.15; }
.brand__name { font-family: var(--font-serif); font-weight: 700; font-size: 1.25rem; color: var(--color-navy); letter-spacing: .01em; }
.brand__role { font-size: 11px; letter-spacing: .14em; color: var(--color-muted); } /* 11px: ロゴ下の英字ラベル。fs-xs(12) より一段小さく by design */
.nav { display: flex; align-items: center; gap: var(--space-8); }
.nav__menu { display: flex; align-items: center; gap: var(--space-8); } /* ナビリンクとCTAの間隔。モバイルではこのまとまりをドロップダウン化する */
.nav__links { display: flex; align-items: center; gap: var(--space-6); list-style: none; margin: 0; padding: 0; }
.nav__links a { font-size: var(--fs-sm); color: var(--color-ink-soft); transition: color var(--dur-fast) var(--ease); }
.nav__links a:hover { color: var(--color-navy); }
.nav__toggle { display: none; background: none; border: 0; color: var(--color-navy); padding: 6px; } /* 6px: アイコンボタンの最小タップ余白 by design */
.nav__toggle .icon { width: 24px; height: 24px; } /* 24px: ハンバーガー/クローズアイコン径 by design */
/* 開閉でアイコンを切替（既定=三本線、.is-open=✕）。aria-expanded と視覚状態を一致させる */
.nav__toggle-icon--close { display: none; }
.nav.is-open .nav__toggle-icon--open { display: none; }
.nav.is-open .nav__toggle-icon--close { display: block; }

/* ---------- Hero ---------- */
.hero { position: relative; overflow: hidden; background: var(--color-bg); }
.hero__media { position: absolute; top: 0; right: 0; bottom: 0; width: 47%; } /* 47%: ヒーロー右側ビジュアルの占有幅 by design */
.hero__media img { width: 100%; height: 100%; object-fit: cover; }
.hero__media::before {
  content: ""; position: absolute; inset: 0;
  /* 左テキスト側へ白くフェードさせるグラデーション — intentional non-token values */
  background: linear-gradient(90deg, #fff 0%, rgba(255,255,255,.55) 22%, rgba(255,255,255,0) 55%);
}
.hero__inner { position: relative; display: flex; align-items: center; min-height: 588px; } /* 588px: ヒーロー最低高さ by design */
.hero__copy { max-width: 640px; padding-block: var(--space-16); } /* 640px: コピー最大幅。見出し2行目「ビジネスの成果をつくる。」を fs-display 上限でも1行に収めるため 580→640 に拡張。上下余白は space-16(64) by design */
.hero__title {
  font-family: var(--font-serif); font-weight: 700;
  font-size: var(--fs-display); line-height: var(--lh-tight);
  letter-spacing: var(--ls-tight); color: var(--color-navy); margin: 0;
}
.hero__sub { margin: var(--space-6) 0 0; color: var(--color-ink-soft); font-size: var(--fs-lead); }
.hero__features { display: flex; gap: var(--space-6); margin: var(--space-10) 0 var(--space-10); }
.hero__feature { display: flex; flex-direction: column; align-items: center; text-align: center; gap: var(--space-3); flex: 1; max-width: 150px; } /* 150px: 特徴アイコン1列の最大幅 by design */
.hero__feature .icon { width: 30px; height: 30px; color: var(--color-navy); stroke-width: 1.4; } /* 30px: ヒーロー特徴アイコン径 by design */
.hero__feature span { font-size: var(--fs-xs); line-height: 1.7; color: var(--color-ink-soft); }
.hero__feature + .hero__feature { border-left: 1px solid var(--color-border); padding-left: var(--space-6); }
.hero__cta { display: flex; gap: var(--space-4); flex-wrap: wrap; }

/* ---------- Problems ---------- */
.problems { display: grid; grid-template-columns: repeat(5, 1fr); gap: var(--space-5); }
.problem { text-align: center; display: flex; flex-direction: column; align-items: center; gap: var(--space-4); }
.problem__text { font-size: var(--fs-sm); line-height: 1.7; color: var(--color-ink); }

/* ---------- Strength ---------- */
.strength { display: grid; grid-template-columns: 0.92fr 1.08fr; align-items: stretch; } /* 0.92/1.08: 画像と本文の左右比 by design */
.strength__outer { padding-inline: 0; } /* 本文側コンテナの左右余白は strength__body 側で制御するためゼロ */
.strength__media { position: relative; min-height: 460px; } /* 460px: 強みセクション画像の最低高さ by design */
.strength__media img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.strength__body { padding: var(--section-pad-y) var(--gutter) var(--section-pad-y) clamp(32px, 5vw, 72px); display: flex; flex-direction: column; justify-content: center; } /* 左: 画像との間隔 clamp(32-72) by design / 右: 他セクションと同じ固定ガター(24px)。本文側(lead 540 / grid 580)が幅を持つため右端揃えの calc は不要 */
.strength__title { font-family: var(--font-serif); font-weight: 700; font-size: var(--fs-h1); line-height: var(--lh-heading); color: var(--color-navy); margin: 0; letter-spacing: var(--ls-tight); }
.strength__lead { margin: var(--space-5) 0 var(--space-8); color: var(--color-ink-soft); max-width: 540px; } /* 540px: リード文の最大行長 by design */
.strength__grid { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-4); max-width: 580px; } /* 580px: チェック項目グリッドの最大幅 by design */

/* ---------- Results / Genre panel ---------- */
.results-panel {
  display: grid; grid-template-columns: 0.85fr 1.15fr; /* 0.85/1.15: 数値と対応ジャンルの左右比 by design */
  border: 1px solid var(--color-border); border-radius: var(--radius-md);
  background: var(--color-bg); overflow: hidden;
}
.results-stat { text-align: center; padding: var(--space-12) var(--space-8); border-right: 1px solid var(--color-border); display: flex; flex-direction: column; align-items: center; justify-content: center; }
.results-stat__label { font-size: var(--fs-sm); font-weight: 700; color: var(--color-navy); }
.results-stat__num { font-family: var(--font-serif); font-weight: 700; color: var(--color-gold); line-height: 1; margin: var(--space-4) 0 var(--space-3); display: flex; align-items: baseline; gap: var(--space-1); }
.results-stat__num b { font-size: 5rem; font-weight: 700; } /* 5rem(80px): 実績数値の強調表示 by design */
.results-stat__num em { font-style: normal; font-size: 1.5rem; color: var(--color-gold); } /* 1.5rem(24px): 「累計」「+」の補助文字 by design */
.results-stat__num i { font-style: normal; font-size: 1.125rem; color: var(--color-ink); align-self: flex-end; margin-bottom: 6px; } /* 1.125rem(18px): 「本以上」/ margin-bottom 6px でベースライン微調整 by design */
.results-stat__note { font-size: var(--fs-xs); color: var(--color-muted); }
.results-genre { padding: var(--space-10) var(--space-10); }
.results-genre__title { font-size: var(--fs-body); font-weight: 700; color: var(--color-navy); margin: 0 0 var(--space-5); }
.results-genre__chips { display: flex; flex-wrap: wrap; gap: var(--space-3); margin-bottom: var(--space-6); }
.results-genre__note { font-size: var(--fs-sm); color: var(--color-muted); margin: 0; }

/* ---------- Services ---------- */
.services { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--space-5); }
.service__icon { color: var(--color-navy); margin-bottom: var(--space-5); }
.service__icon .icon { width: 36px; height: 36px; stroke-width: 1.4; } /* 36px: サービスカードのアイコン径 by design */
.service__title { font-family: var(--font-serif); font-size: var(--fs-h3); font-weight: 700; color: var(--color-navy); margin: 0 0 var(--space-4); }
.service__list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: var(--space-2); }
.service__list li { position: relative; padding-left: var(--space-4); font-size: var(--fs-sm); color: var(--color-ink-soft); }
.service__list li::before { content: ""; position: absolute; left: 0; top: 12px; width: 5px; height: 5px; border-radius: 50%; background: var(--color-gold); } /* 5px: リスト先頭の小さなゴールド点 / top 12px で行頭に揃える by design */

/* ---------- Sample ---------- */
.sample { display: grid; grid-template-columns: 0.95fr 1.05fr; gap: clamp(32px, 5vw, 72px); align-items: stretch; } /* 0.95/1.05: 画像と本文の左右比 by design / stretch: 画像を本文ブロックと同じ高さに揃え下部の余白をなくす */
.sample__media { border-radius: var(--radius-md); overflow: hidden; box-shadow: var(--shadow-card); }
.sample__media img { width: 100%; height: 100%; object-fit: cover; } /* 本文と同じ高さに収める。固定の 16/10 クロップや height 属性(916)由来の縦伸びを避け、余白を出さない by request */
.sample__title { font-family: var(--font-serif); font-size: var(--fs-h2); font-weight: 700; color: var(--color-navy); margin: 0 0 var(--space-4); }
.sample__intro { color: var(--color-ink-soft); font-size: var(--fs-sm); margin: 0 0 var(--space-6); }
.sample__links { list-style: none; margin: 0 0 var(--space-8); padding: 0; display: flex; flex-direction: column; }
.sample__links li { border-bottom: 1px solid var(--color-border); }
.sample__links span { display: flex; align-items: center; gap: var(--space-3); padding: var(--space-4) 0; font-size: var(--fs-body); color: var(--color-navy); }
.sample__links span .icon { width: 16px; height: 16px; color: var(--color-gold); } /* 16px: 項目先頭のファイルアイコン径 by design */

/* ---------- Process / Flow ---------- */
.flow { display: grid; grid-template-columns: repeat(5, 1fr); gap: 0; align-items: start; }
.flow__step { text-align: center; padding-inline: var(--space-3); position: relative; }
.flow__num { display: block; font-size: var(--fs-xs); font-weight: 700; letter-spacing: .14em; color: var(--color-gold); margin-bottom: var(--space-3); }
.flow__icon { margin: 0 auto var(--space-4); width: 64px; height: 64px; } /* 64px: フローのアイコンサークル径（icon-circle より大きめ）by design */
.flow__icon.icon-circle .icon { width: 26px; height: 26px; } /* 26px: フローアイコン内のグリフ径 by design */
.flow__title { font-size: var(--fs-body); font-weight: 700; color: var(--color-navy); margin: 0 0 var(--space-3); }
.flow__desc { font-size: var(--fs-xs); line-height: 1.75; color: var(--color-muted); }
.flow__step:not(:last-child)::after {
  content: ""; position: absolute; top: 92px; right: -10px; width: 20px; height: 20px; /* 92px: アイコン中央高さに矢印を合わせる / -10px: ステップ間の中央に配置 by design */
  border-top: 1.5px solid var(--color-gold-soft); border-right: 1.5px solid var(--color-gold-soft);
  transform: rotate(45deg);
}

/* ---------- CTA band ---------- */
.cta-band { position: relative; overflow: hidden; text-align: center; color: #fff; }
.cta-band__bg { position: absolute; inset: 0; }
.cta-band__bg img { width: 100%; height: 100%; object-fit: cover; }
.cta-band__bg::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(22,34,60,.88), rgba(22,34,60,.92)); } /* navy オーバーレイ — intentional non-token values */
.cta-band__inner { position: relative; padding-block: clamp(64px, 6vw, 104px); } /* clamp: CTA帯の上下余白 by design */
.cta-band__title { font-family: var(--font-serif); font-size: var(--fs-h1); font-weight: 700; line-height: 1.55; margin: 0; }
.cta-band__btn { margin-top: var(--space-8); }

/* ---------- Footer ---------- */
.site-footer { background: var(--color-navy-deep); color: var(--color-on-navy-muted); }
.site-footer__top { display: grid; grid-template-columns: 1.4fr 1fr 1.2fr auto; gap: var(--space-12); padding-block: var(--space-16); } /* 1.4/1/1.2/auto: フッター4カラムの比 by design */
.footer-brand__name { font-family: var(--font-serif); font-weight: 700; font-size: 1.25rem; color: #fff; }
.footer-brand__role { font-size: 11px; letter-spacing: .14em; color: var(--color-on-navy-muted); margin-top: 2px; } /* 11px: 英字ラベル / margin-top 2px の微調整 by design */
.footer-brand__desc { font-size: var(--fs-sm); line-height: 1.9; margin-top: var(--space-5); max-width: 280px; } /* 280px: 紹介文の最大行長 by design */
.footer-col__title { font-size: var(--fs-sm); font-weight: 700; color: #fff; margin: 0 0 var(--space-5); }
.footer-col__list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: var(--space-3); }
.footer-col__list a, .footer-col p { font-size: var(--fs-sm); color: var(--color-on-navy-muted); transition: color var(--dur-fast) var(--ease); }
.footer-col__list a:hover { color: #fff; }
.footer-col p { margin: 0 0 var(--space-5); line-height: 1.9; }
.footer-social { display: flex; gap: var(--space-3); }
.footer-social a { display: inline-flex; align-items: center; justify-content: center; width: 40px; height: 40px; border-radius: 50%; border: 1px solid rgba(255,255,255,.25); color: #fff; transition: background var(--dur) var(--ease); } /* 40px: ソーシャル丸ボタン径（タップターゲット）by design */
.footer-social a:hover { background: rgba(255,255,255,.1); }
.footer-social .icon { width: 18px; height: 18px; } /* 18px: ソーシャルアイコン径 by design */
.site-footer__bottom { border-top: 1px solid rgba(255,255,255,.12); padding-block: var(--space-5); text-align: center; }
.site-footer__bottom small { font-size: var(--fs-xs); color: var(--color-on-navy-muted); letter-spacing: .04em; }

/* ---------- Reveal animation ---------- */
.reveal { opacity: 0; transform: translateY(16px); transition: opacity .7s var(--ease), transform .7s var(--ease); } /* translateY 16px / .7s: スクロール表示の控えめな立ち上がり by design */
.reveal.is-in { opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce) { .reveal { opacity: 1; transform: none; } }

/* ============ Responsive ============ */
@media (max-width: 980px) {
  .hero__media { position: static; width: 100%; height: 280px; } /* 280px: モバイルでのヒーロー画像高さ by design */
  .hero__media::before { background: linear-gradient(0deg, #fff 0%, rgba(255,255,255,0) 40%); } /* 下端フェード — intentional non-token values */
  .hero__inner { display: block; min-height: 0; }
  .hero__copy { max-width: none; padding-block: 48px 32px; } /* 48/32: モバイルのヒーロー上下余白 by design */
  .strength { grid-template-columns: 1fr; }
  .strength__media { min-height: 280px; order: -1; } /* 280px: モバイルの強み画像高さ by design */
  .strength__body { padding: var(--space-12) var(--gutter); } /* 縦積み時は左右にガター(24px)を確保。0 だとテキストが画面端に張り付く */
  .sample { grid-template-columns: 1fr; }
  .sample__media img { height: 150px; aspect-ratio: auto; } /* 150px: モバイルでは補助的な細バナーに抑える。装飾画像(strength 280px)より明確に小さくし、ジャンル等のテキストを主役にする by request */
  .results-panel { grid-template-columns: 1fr; }
  .results-stat { border-right: 0; border-bottom: 1px solid var(--color-border); }
  .services { grid-template-columns: repeat(2, 1fr); }
  .problems { grid-template-columns: repeat(2, 1fr); }
  .flow { grid-template-columns: repeat(2, 1fr); gap: var(--space-8) var(--space-4); }
  .flow__step:not(:last-child)::after { display: none; }
  .site-footer__top { grid-template-columns: 1fr 1fr; gap: var(--space-10); }
}
@media (max-width: 720px) {
  /* モバイル: ナビをハンバーガー開閉式に。既定は折りたたみ、.is-open でドロップダウン表示 */
  .nav__menu { display: none; }
  .nav__toggle { display: inline-flex; }
  .nav.is-open .nav__menu {
    display: flex; flex-direction: column; align-items: stretch; gap: var(--space-2);
    position: absolute; top: 76px; left: 0; right: 0; /* 76px: ヘッダー高さ直下に全幅で展開 */
    background: rgba(255, 255, 255, .98); /* frosted glass — intentional non-token value */
    -webkit-backdrop-filter: saturate(120%) blur(8px); /* iOS Safari 旧版はプレフィックス必須 */
    backdrop-filter: saturate(120%) blur(8px);
    border-bottom: 1px solid var(--color-border-soft);
    box-shadow: var(--shadow-xs);
    padding: var(--space-4) var(--gutter);
  }
  .nav.is-open .nav__links { flex-direction: column; align-items: stretch; gap: var(--space-1); }
  .nav.is-open .nav__links a { display: block; padding: var(--space-3) 0; } /* 縦積み時のタップ領域確保 */
  .nav.is-open .btn--pill { align-self: flex-start; margin-top: var(--space-2); }
  .hero__features { gap: var(--space-3); }
  .hero__feature + .hero__feature { padding-left: var(--space-3); }
  .hero__cta .btn { flex: 1; }
  .problems { grid-template-columns: 1fr; }
  .problem { flex-direction: row; text-align: left; gap: var(--space-4); padding: var(--space-4); border: 1px solid var(--color-border); border-radius: var(--radius-sm); background: #fff; }
  .strength__grid { grid-template-columns: 1fr; }
  .services { grid-template-columns: 1fr; }
  .site-footer__top { grid-template-columns: 1fr; gap: var(--space-8); }
  .footer-social { justify-content: flex-start; }
}
