/* =========================================================
   ソラノミチ（soranomiti.com）— 白基調ミニマル・大型タイポ・余白の読み物型
   配色：オフホワイト地 × ほぼ黒 × アクセント1色（くすんだブルーグレー #3f5366）
   フォント：Noto Sans JP のみ（見出し700/900・本文400）
   ※ zeroskill(明朝ライト)／esgfund(ダークデータ)／touishin(暖色マガジン) と
     骨格・配色・フォントを構造レベルで変える（フットプリント回避）
   禁止：グラデーション/角丸ピル/blur+sticky半透明/hover浮き/紫青グラデ/絵文字多用
   ========================================================= */

:root{
  --paper:#fbfbf9;        /* オフホワイト地 */
  --paper-2:#f3f3ef;      /* わずかに沈めた面 */
  --ink:#16181a;          /* ほぼ黒の文字 */
  --ink-soft:#5b6065;     /* 補助テキスト */
  --rule:#e3e3dd;         /* 罫線 */
  --accent:#3f5366;       /* くすんだブルーグレー（唯一のアクセント） */
  --accent-deep:#2b3a48;  /* 同系の濃い側 */
  --maxw:720px;
}

*{box-sizing:border-box;}

html{ -webkit-text-size-adjust:100%; }

body{
  margin:0;
  background:var(--paper);
  color:var(--ink);
  font-family:"Noto Sans JP",system-ui,-apple-system,sans-serif;
  font-weight:400;
  font-size:17px;
  line-height:2.0;          /* 行間広め */
  letter-spacing:.015em;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}

a{ color:var(--accent); text-decoration:none; }
a:hover{ text-decoration:underline; text-underline-offset:3px; }

/* ---------- ヘッダー（不透明・blurなし・stickyなし） ---------- */
.site-head{
  background:var(--paper);
  border-bottom:1px solid var(--rule);
}
.site-head .inner{
  max-width:var(--maxw);
  margin:0 auto;
  padding:26px 24px 22px;
  display:flex;
  align-items:baseline;
  justify-content:space-between;
  flex-wrap:wrap;
  gap:10px;
}
.brand{
  color:var(--ink);
  font-weight:900;
  font-size:20px;
  letter-spacing:.04em;
  line-height:1.3;
  display:flex;
  flex-direction:column;
}
.brand small{
  display:block;
  font-weight:400;
  font-size:11px;
  letter-spacing:.22em;
  color:var(--ink-soft);
  margin-top:4px;
}
.nav{ display:flex; gap:22px; }
.nav a{
  color:var(--ink-soft);
  font-size:14px;
  letter-spacing:.06em;
}
.nav a:hover{ color:var(--ink); text-decoration:none; }

/* ---------- 中央1カラム ---------- */
.wrap{
  max-width:var(--maxw);
  margin:0 auto;
  padding:0 24px 88px;
}

/* ---------- パンくず ---------- */
.crumb{
  font-size:12.5px;
  color:var(--ink-soft);
  letter-spacing:.04em;
  margin:30px 0 10px;
}
.crumb a{ color:var(--ink-soft); }
.crumb a:hover{ color:var(--accent); }

/* ---------- ヒーロー（エッセイ型・大型タイポ・余白大） ---------- */
.hero{ padding:62px 0 46px; border-bottom:1px solid var(--rule); }
.hero .eyebrow{
  font-size:12px;
  letter-spacing:.28em;
  color:var(--accent);
  font-weight:700;
  margin:0 0 22px;
  text-transform:uppercase;
}
.hero h1{
  font-weight:900;
  font-size:clamp(33px,6.4vw,52px);
  line-height:1.32;
  letter-spacing:.01em;
  margin:0 0 28px;
}
.hero .lead{
  font-size:17px;
  color:var(--ink-soft);
  line-height:2.05;
  margin:0;
  max-width:60ch;
}

/* ---------- セクション見出し ---------- */
.sec-h{
  font-weight:900;
  font-size:24px;
  letter-spacing:.02em;
  margin:64px 0 8px;
  padding-bottom:0;
}
.sec-lead{ color:var(--ink-soft); font-size:15px; margin:0 0 26px; }

/* ---------- 記事一覧：シンプルな縦並びテキストリスト ---------- */
.guide-list{
  list-style:none;
  margin:30px 0 0;
  padding:0;
  counter-reset:gl;
}
.guide-list li{
  counter-increment:gl;
  padding:24px 0;
  border-top:1px solid var(--rule);
  display:flex;
  gap:20px;
  align-items:baseline;
}
.guide-list li:last-child{ border-bottom:1px solid var(--rule); }
.guide-list li::before{
  content:counter(gl,decimal-leading-zero);
  font-weight:700;
  font-size:13px;
  color:var(--accent);
  letter-spacing:.08em;
  flex:0 0 auto;
  min-width:26px;
  padding-top:3px;
}
.guide-list a{
  color:var(--ink);
  font-weight:700;
  font-size:18.5px;
  line-height:1.6;
  letter-spacing:.01em;
}
.guide-list a:hover{ color:var(--accent); text-decoration:none; }
.guide-list .meta{
  color:var(--ink-soft);
  font-size:12.5px;
  letter-spacing:.05em;
  margin-top:8px;
}

/* ---------- 記事本文ラッパ ---------- */
.post{ padding-top:8px; }
.post h1{
  font-weight:900;
  font-size:clamp(28px,5vw,40px);
  line-height:1.4;
  letter-spacing:.01em;
  margin:14px 0 18px;
}
.post-meta{
  font-size:13px;
  color:var(--ink-soft);
  letter-spacing:.04em;
  padding-bottom:30px;
  margin-bottom:34px;
  border-bottom:1px solid var(--rule);
}
.post-meta .author{ color:var(--accent); font-weight:700; }
.post h2{
  font-weight:900;
  font-size:25px;
  line-height:1.5;
  letter-spacing:.01em;
  margin:62px 0 18px;
  padding-left:16px;
  border-left:4px solid var(--accent);
}
.post h3{
  font-weight:700;
  font-size:19px;
  line-height:1.55;
  margin:40px 0 12px;
}
.post p{ margin:0 0 24px; }
.post strong{ font-weight:700; }
.post ul,.post ol{ margin:0 0 26px; padding-left:1.4em; }
.post li{ margin:0 0 12px; line-height:1.95; }

/* ---------- 表 ---------- */
.tbl{
  width:100%;
  border-collapse:collapse;
  margin:14px 0 30px;
  font-size:15px;
  line-height:1.8;
}
.tbl th,.tbl td{
  border:1px solid var(--rule);
  padding:13px 15px;
  text-align:left;
  vertical-align:top;
}
.tbl th{
  background:var(--paper-2);
  font-weight:700;
  color:var(--ink);
  white-space:nowrap;
}
.tbl tr td:first-child{ background:#fcfcfb; }

/* ---------- ノート / 引用 ---------- */
.note{
  background:var(--paper-2);
  border-left:3px solid var(--accent);
  padding:22px 24px;
  margin:30px 0;
  font-size:15.5px;
  line-height:2.0;
  color:var(--ink);
}
.note .label{
  display:block;
  font-weight:700;
  font-size:12.5px;
  letter-spacing:.1em;
  color:var(--accent);
  margin-bottom:8px;
}
blockquote{
  margin:30px 0;
  padding:6px 0 6px 22px;
  border-left:3px solid var(--rule);
  color:var(--ink-soft);
  font-size:16px;
  line-height:1.95;
}

/* ---------- CTA ---------- */
.cta{
  border:1px solid var(--rule);
  background:#fff;
  padding:30px 28px;
  margin:44px 0;
}
.cta .ttl{
  font-weight:900;
  font-size:18px;
  letter-spacing:.01em;
  margin:0 0 10px;
}
.cta p{ margin:0 0 14px; font-size:15.5px; line-height:1.95; color:var(--ink-soft); }
.asp-placeholder{
  margin-top:6px;
  padding:18px;
  border:1px dashed #b9bbb6;
  background:var(--paper-2);
  text-align:center;
  font-size:13px;
  letter-spacing:.04em;
  color:var(--ink-soft);
}

/* ---------- 著者カード ---------- */
.author-card{
  display:flex;
  gap:18px;
  align-items:flex-start;
  margin:56px 0 30px;
  padding:26px 0;
  border-top:1px solid var(--rule);
  border-bottom:1px solid var(--rule);
}
.author-card .av{
  flex:0 0 auto;
  width:54px;height:54px;
  background:var(--accent-deep);
  color:#fff;
  font-weight:700;
  font-size:22px;
  display:flex;
  align-items:center;
  justify-content:center;
  letter-spacing:.02em;
}
.author-card .nm{ font-weight:700; font-size:16px; margin-bottom:6px; }
.author-card .bio{ font-size:14px; color:var(--ink-soft); line-height:1.85; }

/* ---------- disclaimer ---------- */
.disclaimer{
  font-size:12.5px;
  line-height:1.95;
  color:var(--ink-soft);
  margin:34px 0 0;
  padding:18px 0 0;
  border-top:1px solid var(--rule);
}

/* ---------- フォーム ---------- */
.form label{ display:block; font-weight:700; font-size:14px; margin:20px 0 6px; }
.form input,.form textarea{
  width:100%;
  padding:12px 13px;
  border:1px solid var(--rule);
  background:#fff;
  font-family:inherit;
  font-size:15px;
  color:var(--ink);
}
.form input:focus,.form textarea:focus{ outline:2px solid var(--accent); outline-offset:1px; }
.form textarea{ min-height:160px; resize:vertical; }
.form button{
  margin-top:24px;
  padding:13px 32px;
  background:var(--accent-deep);
  color:#fff;
  border:0;
  cursor:pointer;
  font-family:inherit;
  font-size:15px;
  letter-spacing:.06em;
}
.form button:hover{ background:var(--accent); }

/* ---------- フッター ---------- */
.site-foot{
  border-top:1px solid var(--rule);
  background:var(--paper);
  margin-top:40px;
}
.site-foot .inner{
  max-width:var(--maxw);
  margin:0 auto;
  padding:38px 24px 50px;
  text-align:center;
}
.site-foot nav{ display:flex; gap:20px; justify-content:center; flex-wrap:wrap; }
.site-foot nav a{ color:var(--ink-soft); font-size:13px; letter-spacing:.05em; }
.site-foot nav a:hover{ color:var(--accent); text-decoration:none; }
.site-foot p{ color:var(--ink-soft); font-size:12px; letter-spacing:.05em; }

/* ---------- 内部リンク行 ---------- */
.rellinks{ margin:40px 0 0; padding:0; list-style:none; }
.rellinks li{ padding:14px 0; border-top:1px solid var(--rule); }
.rellinks li:last-child{ border-bottom:1px solid var(--rule); }
.rellinks a{ font-weight:700; font-size:15.5px; }

/* ---------- レスポンシブ ---------- */
@media(max-width:620px){
  body{ font-size:16px; }
  .site-head .inner{ padding:20px 18px 18px; }
  .wrap{ padding:0 18px 64px; }
  .hero{ padding:44px 0 36px; }
  .nav{ gap:16px; }
  .guide-list li{ gap:14px; }
  .post h2{ font-size:21px; }
}
