@charset "UTF-8";
/* ============================================================
   給料＋αの研究室 (salaryroom.com)
   デザイン系統：ノート / 家計簿型
   オフホワイト地 × グリーン(#2f7d5b) × チャコール文字
   方眼/罫線ノートの雰囲気・1カラム・収支表が主役
   フォント：Noto Sans JP（明朝禁止）
   禁止：グラデ / 角丸ピル / blur sticky / hover浮き / 紫青グラデ
   ============================================================ */

:root{
  --paper:      #fbfbf6;   /* 明るいオフホワイト地 */
  --paper-2:    #ffffff;   /* カード白 */
  --paper-3:    #f4f5ec;   /* 薄い帯 */
  --ink:        #2b2f2c;   /* チャコール文字 */
  --ink-soft:   #5c625d;
  --ink-faint:  #868c86;
  --accent:     #2f7d5b;   /* 落ち着いたグリーン */
  --accent-deep:#256348;
  --accent-pale:#e7f1ea;
  --rule:       #d8dccf;   /* 罫線色 */
  --rule-soft:  #e8ebdf;
  --grid:       #eceee2;   /* 方眼線 */
  --warn:       #b06a2b;
  --maxw:       760px;
}

*{box-sizing:border-box;}
html{ -webkit-text-size-adjust:100%; }
body{
  margin:0;
  font-family:"Noto Sans JP",-apple-system,BlinkMacSystemFont,"Hiragino Kaku Gothic ProN","Yu Gothic",sans-serif;
  color:var(--ink);
  background-color:var(--paper);
  /* 方眼ノートの薄い格子 */
  background-image:
    linear-gradient(var(--grid) 1px, transparent 1px),
    linear-gradient(90deg, var(--grid) 1px, transparent 1px);
  background-size:26px 26px;
  font-size:16px;
  line-height:1.9;
  font-weight:400;
}

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

/* ---------- ヘッダー：罫線ノートの綴じ込み風 ---------- */
.site-head{
  background:var(--paper-2);
  border-bottom:2px solid var(--accent);
}
.site-head .inner{
  max-width:var(--maxw);
  margin:0 auto;
  padding:14px 20px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  flex-wrap:wrap;
  gap:8px;
}
.brand{
  display:flex;
  flex-direction:column;
  line-height:1.25;
  color:var(--ink);
  font-weight:700;
  font-size:19px;
  letter-spacing:.02em;
}
.brand:hover{ text-decoration:none; }
.brand small{
  font-weight:500;
  font-size:11px;
  color:var(--accent);
  letter-spacing:.14em;
  margin-top:2px;
}
.nav{ display:flex; gap:18px; font-size:14px; }
.nav a{ color:var(--ink-soft); font-weight:500; }

/* ---------- 本文ラッパ ---------- */
.wrap{
  max-width:var(--maxw);
  margin:0 auto;
  padding:26px 20px 60px;
}

/* ---------- パンくず ---------- */
.crumb{
  font-size:13px;
  color:var(--ink-faint);
  margin:0 0 20px;
}
.crumb a{ color:var(--ink-soft); }

/* ---------- 記事本体（罫線ノートカード） ---------- */
.post{
  background:var(--paper-2);
  border:1px solid var(--rule);
  border-left:4px solid var(--accent);
  padding:34px 32px 36px;
}
.post h1{
  font-size:27px;
  line-height:1.5;
  font-weight:700;
  margin:0 0 12px;
  letter-spacing:.01em;
}
.post-meta{
  font-size:13px;
  color:var(--ink-faint);
  border-bottom:1px dashed var(--rule);
  padding-bottom:14px;
  margin-bottom:24px;
}
.post-meta .author{ color:var(--accent-deep); font-weight:500; }

.post h2{
  font-size:20px;
  font-weight:700;
  margin:40px 0 14px;
  padding:6px 0 6px 14px;
  border-left:6px solid var(--accent);
  background:var(--accent-pale);
  line-height:1.5;
}
.post h3{
  font-size:17px;
  font-weight:700;
  margin:28px 0 10px;
  padding-bottom:6px;
  border-bottom:2px dotted var(--rule);
}
.post p{ margin:0 0 16px; }
.post ul,.post ol{ margin:0 0 18px; padding-left:1.4em; }
.post li{ margin:6px 0; }
.post strong{ color:var(--accent-deep); font-weight:700; }

/* ---------- 収支 / シミュレーション表（主役） ---------- */
.tbl{
  width:100%;
  border-collapse:collapse;
  margin:18px 0 22px;
  font-size:14.5px;
  background:var(--paper-2);
}
.tbl caption{
  caption-side:top;
  text-align:left;
  font-size:13px;
  font-weight:700;
  color:var(--accent-deep);
  padding:0 0 8px;
}
.tbl th,.tbl td{
  border:1px solid var(--rule);
  padding:10px 12px;
  text-align:left;
  vertical-align:top;
}
.tbl thead th,.tbl tr:first-child th{
  background:var(--accent);
  color:#fff;
  font-weight:700;
  letter-spacing:.02em;
}
.tbl tbody tr:nth-child(even) td{ background:var(--paper-3); }
.tbl td.num,.tbl th.num{ text-align:right; font-variant-numeric:tabular-nums; }
.tbl .total td{ background:var(--accent-pale); font-weight:700; }

/* ---------- ノート（手書きメモ風の付箋） ---------- */
.note{
  background:var(--paper-3);
  border:1px solid var(--rule);
  border-top:3px solid var(--accent);
  padding:16px 18px;
  margin:24px 0;
  font-size:14.5px;
  line-height:1.85;
  position:relative;
}
.note .label{
  display:inline-block;
  font-weight:700;
  font-size:12px;
  color:var(--accent-deep);
  letter-spacing:.08em;
  margin-bottom:6px;
}
.note::before{
  content:"✎";
  position:absolute;
  top:12px; right:16px;
  color:var(--accent);
  font-size:16px;
  opacity:.6;
}

/* ---------- CTA + ASPプレースホルダ ---------- */
.cta{
  background:var(--accent-pale);
  border:1px dashed var(--accent);
  padding:22px 22px;
  margin:30px 0;
}
.cta .ttl{
  font-weight:700;
  font-size:16px;
  color:var(--accent-deep);
  margin:0 0 8px;
}
.cta p{ margin:0 0 12px; font-size:15px; }
.asp-placeholder{
  margin-top:14px;
  padding:18px 14px;
  text-align:center;
  font-size:13px;
  color:var(--ink-faint);
  background:repeating-linear-gradient(
    -45deg,#f0f2e9,#f0f2e9 8px,#e8ebdf 8px,#e8ebdf 16px);
  border:1px solid var(--rule);
}

/* ---------- 著者カード ---------- */
.author-card{
  display:flex;
  gap:16px;
  align-items:flex-start;
  background:var(--paper-2);
  border:1px solid var(--rule);
  border-left:4px solid var(--accent);
  padding:18px 20px;
  margin:34px 0 24px;
}
.author-card .av{
  flex:0 0 auto;
  width:48px; height:48px;
  background:var(--accent);
  color:#fff;
  display:flex; align-items:center; justify-content:center;
  font-weight:700; font-size:20px;
}
.author-card .nm{ font-weight:700; font-size:15px; margin-bottom:4px; }
.author-card .bio{ font-size:13px; color:var(--ink-soft); line-height:1.8; }

/* ---------- 関連リンク ---------- */
.related{
  margin:28px 0 4px;
  padding:18px 20px;
  background:var(--paper-3);
  border:1px solid var(--rule);
}
.related .label{
  font-weight:700; font-size:13px; color:var(--accent-deep);
  letter-spacing:.06em; margin-bottom:10px;
}
.related ul{ list-style:none; margin:0; padding:0; }
.related li{ margin:8px 0; padding-left:20px; position:relative; }
.related li::before{
  content:"□"; position:absolute; left:0; top:0; color:var(--accent);
}

/* ---------- disclaimer ---------- */
.disclaimer{
  margin-top:30px;
  padding:16px 18px;
  font-size:12.5px;
  line-height:1.8;
  color:var(--ink-soft);
  background:var(--paper-3);
  border:1px solid var(--rule);
}

/* ============================================================
   トップページ
   ============================================================ */
.lede{
  background:var(--paper-2);
  border:1px solid var(--rule);
  border-left:4px solid var(--accent);
  padding:30px 30px 26px;
  margin-bottom:30px;
}
.lede .eyebrow{
  font-size:12px; letter-spacing:.16em; color:var(--accent);
  font-weight:700; margin:0 0 10px;
}
.lede h1{
  font-size:26px; line-height:1.55; font-weight:700; margin:0 0 14px;
}
.lede .lead{ font-size:15.5px; color:var(--ink-soft); margin:0; }

/* 月次収支イメージ（トップの図解） */
.budget-strip{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:0;
  margin:22px 0 30px;
  border:1px solid var(--rule);
  background:var(--paper-2);
}
.budget-strip .cell{
  padding:16px 14px;
  border-right:1px dashed var(--rule);
}
.budget-strip .cell:last-child{ border-right:0; }
.budget-strip .k{ font-size:12px; color:var(--ink-faint); letter-spacing:.04em; }
.budget-strip .v{ font-size:20px; font-weight:700; color:var(--accent-deep); margin-top:4px; }
.budget-strip .n{ font-size:12px; color:var(--ink-soft); margin-top:4px; }

.sec-h{
  font-size:19px; font-weight:700; margin:30px 0 14px;
  padding-left:12px; border-left:6px solid var(--accent);
}

/* ---------- 記事一覧：チェックリスト風 ---------- */
.guide-list{
  list-style:none;
  margin:0; padding:0;
  background:var(--paper-2);
  border:1px solid var(--rule);
}
.guide-list li{
  display:flex; gap:14px;
  padding:16px 18px;
  border-bottom:1px solid var(--rule-soft);
}
.guide-list li:last-child{ border-bottom:0; }
.guide-list li::before{
  content:"□";
  flex:0 0 auto;
  color:var(--accent);
  font-size:20px;
  line-height:1.4;
}
.guide-list li > div{ flex:1 1 auto; }
.guide-list a{ font-size:16px; font-weight:700; color:var(--ink); }
.guide-list a:hover{ color:var(--accent-deep); }
.guide-list .meta{ font-size:12.5px; color:var(--ink-faint); margin-top:5px; }

/* ---------- フォーム ---------- */
.form label{ display:block; font-weight:500; font-size:14px; margin:18px 0 6px; }
.form input,.form textarea{
  width:100%; padding:11px 12px;
  border:1px solid var(--rule); background:var(--paper-2);
  font-family:inherit; font-size:15px; color:var(--ink);
}
.form textarea{ min-height:150px; resize:vertical; }
.form button{
  margin-top:22px; padding:12px 30px;
  background:var(--accent-deep); color:#fff; border:0;
  cursor:pointer; font-size:15px; letter-spacing:.04em; font-family:inherit;
}
.form button:hover{ background:var(--accent); }

/* ---------- フッター ---------- */
.site-foot{
  background:var(--paper-2);
  border-top:2px solid var(--accent);
  margin-top:40px;
}
.site-foot .inner{
  max-width:var(--maxw);
  margin:0 auto;
  padding:26px 20px 34px;
  text-align:center;
}
.site-foot nav{ display:flex; flex-wrap:wrap; gap:16px; justify-content:center; font-size:13px; }
.site-foot a{ color:var(--ink-soft); }
.site-foot p{ font-size:12px; color:var(--ink-faint); }

/* ---------- レスポンシブ ---------- */
@media(max-width:600px){
  body{ background-size:22px 22px; }
  .post{ padding:24px 18px 28px; }
  .post h1{ font-size:23px; }
  .lede{ padding:24px 20px; }
  .lede h1{ font-size:22px; }
  .budget-strip{ grid-template-columns:1fr; }
  .budget-strip .cell{ border-right:0; border-bottom:1px dashed var(--rule); }
  .budget-strip .cell:last-child{ border-bottom:0; }
  .tbl{ font-size:13.5px; }
  .tbl th,.tbl td{ padding:8px 9px; }
}
