/* =========================================================
   長谷川サミン ポートフォリオ — 装丁本テーマ
   設計: クリーム紙 × インク × 臙脂 / 明朝・オールドスタイルセリフ
        小さめの文字・ゆったりした行間 / 章立て・飾り罫・ドロップキャップ
   ========================================================= */
:root{
  --paper:#f6f1e7;        /* 紙 */
  --paper-2:#efe8d8;      /* 章扉・差し色の地 */
  --paper-3:#e9e0cd;
  --ink:#2b2620;          /* 本文インク（温かい黒） */
  --ink-2:#4b4339;
  --muted:#766b5b;        /* 補助 */
  --muted-2:#9a8f7c;
  --rule:#ddd2bd;         /* 罫線 */
  --rule-2:#cabfa6;
  --accent:#8a3324;       /* 臙脂（アクセント1色） */
  --accent-d:#6d2418;
  --accent-soft:#f0e3d8;
  --gold:#9c7a3c;         /* 箔の代わりの控えめな金 */
  --radius:3px;
  --shadow:0 1px 0 rgba(43,38,32,.04), 0 14px 34px -22px rgba(43,38,32,.5);
  --maxw:1000px;
  --measure:64ch;
  --serif:"Iowan Old Style","Palatino Linotype","Palatino","Book Antiqua",
          "Hiragino Mincho ProN","Yu Mincho","YuMincho","Noto Serif JP",
          "Times New Roman",serif;
  --label:"Iowan Old Style","Palatino","Hiragino Mincho ProN","Yu Mincho",serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;color:var(--ink);background-color:var(--paper);
  font-family:var(--serif);font-size:15px;line-height:1.85;letter-spacing:.012em;
  font-feature-settings:"palt";-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  background-image:
    radial-gradient(1200px 700px at 50% -10%, rgba(255,255,255,.5), transparent 60%),
    radial-gradient(900px 900px at 100% 100%, rgba(154,143,124,.06), transparent 60%);
}
img,svg{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3{margin:0;font-weight:600;line-height:1.32;letter-spacing:.005em;color:var(--ink)}
p{margin:0}

.container{max-width:var(--maxw);margin:0 auto;padding:0 28px}
.label{font-family:var(--label);font-size:11.5px;letter-spacing:.34em;text-transform:uppercase;
  color:var(--muted);font-weight:600;font-style:normal}
.accent{color:var(--accent)}
.muted{color:var(--muted)}
.measure{max-width:var(--measure)}

/* 章セクション */
.section{padding:clamp(48px,7vw,86px) 0}
.section--tint{background:var(--paper-2);border-top:1px solid var(--rule);border-bottom:1px solid var(--rule)}

/* 章見出し（I — 強み のような扉） */
.chapter{display:flex;align-items:center;gap:16px;margin-bottom:30px}
.chapter .ch-no{font-family:var(--label);font-size:12px;letter-spacing:.26em;color:var(--accent);
  font-style:italic;font-weight:600}
.chapter .ch-line{flex:1;height:1px;background:linear-gradient(90deg,var(--rule-2),transparent)}
.chapter .ch-title{font-size:11.5px;letter-spacing:.34em;text-transform:uppercase;color:var(--muted);
  font-family:var(--label);font-weight:600}

.h-sec{font-size:clamp(21px,3vw,30px);letter-spacing:.01em;font-weight:600}
.lead{color:var(--ink-2);font-size:clamp(14.5px,1.5vw,16px);max-width:var(--measure);margin-top:14px;
  line-height:1.95}

/* ドロップキャップ */
.dropcap::first-letter{float:left;font-size:3.2em;line-height:.84;padding:6px 10px 0 0;
  color:var(--accent);font-weight:600}

/* 飾り罫（SVG flourishの周り） */
.flourish{display:flex;align-items:center;justify-content:center;gap:16px;margin:6px 0;color:var(--rule-2)}
.flourish svg{width:120px;height:14px;color:var(--accent);opacity:.85}
.flourish .l{height:1px;width:90px;background:linear-gradient(90deg,transparent,var(--rule-2))}
.flourish .r{height:1px;width:90px;background:linear-gradient(90deg,var(--rule-2),transparent)}

/* リンク（本文中の参照） */
.ref{color:var(--accent);text-decoration:underline;text-decoration-thickness:1px;
  text-underline-offset:3px;text-decoration-color:var(--rule-2);font-style:italic}
.ref:hover{text-decoration-color:var(--accent)}

/* ボタン（活版のラベルふう） */
.btn{display:inline-flex;align-items:center;gap:9px;font-family:var(--serif);font-size:14px;
  letter-spacing:.04em;padding:10px 20px;border-radius:var(--radius);border:1px solid var(--ink);
  cursor:pointer;transition:background .18s,color .18s,transform .12s,border-color .18s;background:transparent;color:var(--ink)}
.btn:active{transform:translateY(1px)}
.btn--primary{background:var(--accent);border-color:var(--accent);color:#f7efe6}
.btn--primary:hover{background:var(--accent-d);border-color:var(--accent-d)}
.btn--ghost:hover{background:var(--ink);color:var(--paper)}
.btn-row{display:flex;gap:14px;flex-wrap:wrap;margin-top:28px}

/* ナビ（本の柱／ランニングヘッド） */
.nav{position:sticky;top:0;z-index:50;background:rgba(246,241,231,.9);
  backdrop-filter:saturate(140%) blur(8px);border-bottom:1px solid var(--rule)}
.nav__inner{max-width:var(--maxw);margin:0 auto;padding:0 28px;height:60px;
  display:flex;align-items:center;justify-content:space-between;gap:16px}
.brand{font-size:17px;letter-spacing:.06em;font-weight:600}
.brand .sub{font-family:var(--label);font-size:9.5px;letter-spacing:.3em;text-transform:uppercase;
  color:var(--muted);display:block;margin-top:-2px}
.nav__links{display:flex;align-items:center;gap:4px}
.nav__links a{font-size:14px;letter-spacing:.03em;color:var(--ink-2);padding:7px 12px;border-radius:var(--radius);
  transition:color .15s;position:relative}
.nav__links a:hover{color:var(--accent)}
.nav__links a.active{color:var(--accent)}
.nav__links a.active::after{content:"";position:absolute;left:12px;right:12px;bottom:2px;height:1px;
  background:var(--accent)}
.nav__cta{margin-left:8px;border:1px solid var(--rule-2);padding:7px 14px}
.nav__cta:hover{border-color:var(--accent)}
.nav__toggle{display:none;width:40px;height:38px;border:1px solid var(--rule-2);border-radius:var(--radius);
  background:transparent;cursor:pointer;flex-direction:column;align-items:center;justify-content:center;gap:4px}
.nav__toggle span{width:17px;height:1.5px;background:var(--ink)}
@media(max-width:780px){
  .nav__toggle{display:flex}
  .nav__links{position:absolute;top:60px;left:0;right:0;flex-direction:column;align-items:stretch;gap:0;
    background:var(--paper);border-bottom:1px solid var(--rule);padding:8px 18px 16px;
    box-shadow:var(--shadow);transform:translateY(-8px);opacity:0;pointer-events:none;transition:.18s}
  .nav__links.open{transform:none;opacity:1;pointer-events:auto}
  .nav__links a{padding:13px 6px;font-size:16px;border-bottom:1px solid var(--rule)}
  .nav__links a.active::after{display:none}
  .nav__cta{margin:10px 0 0;border:1px solid var(--rule-2);text-align:center}
}

/* 在席の題箋（蔵書票ふう・アイコンなし） */
.plate{display:inline-block;font-family:var(--label);font-size:11.5px;letter-spacing:.22em;
  text-transform:uppercase;color:var(--accent);border:1px solid var(--rule-2);
  padding:6px 16px;border-radius:var(--radius);background:rgba(255,255,255,.4)}

/* ヒーロー（扉ページ） */
.hero{padding:clamp(44px,7vw,84px) 0 clamp(30px,5vw,56px)}
.hero__grid{display:grid;grid-template-columns:1.25fr .75fr;gap:48px;align-items:center}
@media(max-width:820px){.hero__grid{grid-template-columns:1fr;gap:30px}}
.hero h1{font-size:clamp(32px,5.6vw,56px);line-height:1.18;letter-spacing:.01em;margin:18px 0 0;font-weight:600}
.hero h1 em{font-style:italic;color:var(--accent)}
.hero .role{font-family:var(--label);font-size:13px;letter-spacing:.16em;color:var(--muted);margin-top:14px;
  text-transform:uppercase}
.hero .lead{font-size:clamp(15px,1.7vw,17px);margin-top:20px}
.hero__art{display:flex;justify-content:center}
.hero__art svg{width:100%;max-width:300px;height:auto;color:var(--accent)}

/* 標題紙ふうの統計（罫で仕切る） */
.stats{display:grid;grid-template-columns:repeat(4,1fr);margin-top:46px;border-top:1px solid var(--rule-2);
  border-bottom:1px solid var(--rule-2)}
.stat{padding:18px 16px;border-right:1px solid var(--rule)}
.stat:last-child{border-right:none}
.stat .n{font-size:clamp(19px,2.6vw,25px);font-weight:600;letter-spacing:.01em}
.stat .l{font-family:var(--label);font-size:10.5px;letter-spacing:.14em;color:var(--muted);margin-top:5px;
  text-transform:uppercase}
@media(max-width:680px){.stats{grid-template-columns:1fr 1fr}.stat:nth-child(2){border-right:none}
  .stat:nth-child(1),.stat:nth-child(2){border-bottom:1px solid var(--rule)}}

/* 見出し行 */
.sec-head{margin-bottom:34px}
.sec-head .lead{margin-top:12px}
.link-arrow{font-family:var(--label);font-size:12.5px;letter-spacing:.1em;color:var(--accent);
  font-style:italic;display:inline-flex;gap:7px;align-items:center;margin-top:16px}
.link-arrow:hover{gap:11px}

/* カード（栞・帙ふう） */
.grid{display:grid;gap:1px;background:var(--rule)}
.grid--3{grid-template-columns:repeat(3,1fr)}
.grid--2{grid-template-columns:repeat(2,1fr)}
.grid.plain{background:transparent;gap:20px}
@media(max-width:820px){.grid--3{grid-template-columns:1fr 1fr}}
@media(max-width:600px){.grid--3,.grid--2{grid-template-columns:1fr}}
.card{background:var(--paper);padding:26px 26px 28px;transition:background .2s;position:relative}
.grid.plain .card{border:1px solid var(--rule);border-radius:var(--radius)}
.card:hover{background:var(--paper-2)}
.card .num{font-family:var(--label);font-size:12px;letter-spacing:.18em;color:var(--accent);font-style:italic}
.card h3{font-size:18px;margin:12px 0 9px;font-weight:600}
.card p{color:var(--ink-2);font-size:14px;line-height:1.8}

/* 実績（書誌エントリふう） */
.entry{padding:30px 0;border-top:1px solid var(--rule-2)}
.entry:first-child{border-top:none}
.entry__head{display:flex;align-items:baseline;gap:14px;flex-wrap:wrap;margin-bottom:6px}
.entry__no{font-family:var(--label);font-size:13px;font-style:italic;color:var(--accent);letter-spacing:.08em}
.entry__period{font-family:var(--label);font-size:12px;letter-spacing:.08em;color:var(--muted)}
.entry__role{font-family:var(--label);font-size:11.5px;letter-spacing:.06em;color:var(--ink-2);
  border-left:1px solid var(--rule-2);padding-left:14px}
.entry h3{font-size:clamp(19px,2.5vw,24px);font-weight:600;margin:2px 0 12px;letter-spacing:.01em}
.entry__cols{display:grid;grid-template-columns:1.5fr 1fr;gap:30px}
@media(max-width:740px){.entry__cols{grid-template-columns:1fr;gap:18px}}
.entry p{color:var(--ink-2);font-size:14px;line-height:1.85}
.subhead{font-family:var(--label);font-size:10.5px;letter-spacing:.2em;text-transform:uppercase;
  color:var(--muted-2);margin-bottom:11px;font-weight:600}
.duties{margin:0;padding:0;list-style:none}
.duties li{padding:3px 0 3px 18px;font-size:13.5px;color:var(--ink-2);line-height:1.7;position:relative}
.duties li::before{content:"—";position:absolute;left:0;color:var(--accent)}
.outcome{margin-top:18px;padding:14px 18px;border-left:2px solid var(--accent);background:rgba(255,255,255,.4)}
.outcome p{font-size:13.5px;color:var(--ink-2);font-style:italic;line-height:1.7}
.stack{display:flex;flex-wrap:wrap;gap:7px}
.tag{font-family:var(--label);font-size:11px;letter-spacing:.04em;color:var(--ink-2);
  border:1px solid var(--rule-2);border-radius:var(--radius);padding:4px 10px;background:rgba(255,255,255,.35)}

/* スキル（蔵書の格付けふう） */
.skill{padding:16px 0;border-top:1px solid var(--rule)}
.skill:first-child{border-top:none}
.skill__top{display:flex;justify-content:space-between;align-items:baseline;gap:12px;margin-bottom:8px}
.skill__top b{font-size:15px;font-weight:600}
.skill__top span{font-family:var(--label);font-size:11px;letter-spacing:.06em;color:var(--muted)}
.bar{height:5px;background:var(--paper-3);border-radius:99px;overflow:hidden}
.bar > i{display:block;height:100%;width:0;background:var(--accent);transition:width 1s cubic-bezier(.2,.7,.2,1)}
.skill small{display:block;color:var(--muted);font-size:12.5px;margin-top:8px;line-height:1.6}

/* 自己PR（段組の散文） */
.pr-block{padding:26px 0;border-top:1px solid var(--rule-2)}
.pr-block:first-child{border-top:none}
.pr-block h3{font-size:18px;margin-bottom:12px;font-weight:600;display:flex;gap:14px;align-items:baseline}
.pr-block h3 .n{font-family:var(--label);font-style:italic;color:var(--accent);font-size:15px}
.pr-block p{color:var(--ink-2);font-size:14px;line-height:1.95}

/* 資格（奥付ふう） */
.cred{display:flex;align-items:baseline;gap:14px;padding:14px 0;border-top:1px solid var(--rule)}
.cred:first-child{border-top:none}
.cred b{font-size:15px;font-weight:600}
.cred .yr{font-family:var(--label);font-size:12px;letter-spacing:.08em;color:var(--muted);margin-left:auto}
.cred .lead-dots{flex:1;border-bottom:1px dotted var(--rule-2);transform:translateY(-3px)}

/* 献辞ふうCTA */
.cta{border:1px solid var(--rule-2);border-radius:var(--radius);padding:clamp(30px,5vw,52px);text-align:center;
  background:rgba(255,255,255,.4)}
.cta h2{font-size:clamp(21px,3.2vw,30px);font-weight:600;letter-spacing:.01em}
.cta p{color:var(--ink-2);margin:14px auto 0;max-width:52ch;font-size:14.5px;line-height:1.85}
.cta .btn-row{justify-content:center}

/* 奥付（フッター） */
.footer{border-top:1px solid var(--rule-2);background:var(--paper-2);padding:40px 0 30px;margin-top:8px}
.footer__inner{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:30px}
.footer h4{font-family:var(--label);font-size:10.5px;letter-spacing:.2em;text-transform:uppercase;
  color:var(--muted-2);margin:0 0 12px;font-weight:600}
.footer a{display:block;color:var(--ink-2);font-size:13.5px;padding:3px 0}
.footer a:hover{color:var(--accent)}
.footer__brand b{font-size:16px;letter-spacing:.04em}
.footer__brand p{color:var(--muted);font-size:13px;margin-top:8px;max-width:34ch;line-height:1.75}
.footer__bottom{border-top:1px solid var(--rule);margin-top:30px;padding-top:18px;display:flex;
  justify-content:space-between;flex-wrap:wrap;gap:10px;font-family:var(--label);font-size:11px;
  letter-spacing:.08em;color:var(--muted-2)}
@media(max-width:680px){.footer__inner{grid-template-columns:1fr 1fr}.footer__brand{grid-column:1/-1}}

/* 下層ページの扉 */
.page-head{padding:clamp(44px,6vw,76px) 0 clamp(22px,3vw,38px)}
.page-head h1{font-size:clamp(27px,4.6vw,44px);letter-spacing:.01em;margin-top:14px;font-weight:600}
.page-head h1 em{font-style:italic;color:var(--accent)}

/* 微アニメ（軽量） */
.reveal{opacity:0;transform:translateY(12px)}
.reveal.in{opacity:1;transform:none;transition:opacity .6s ease,transform .6s cubic-bezier(.2,.7,.2,1)}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none}*{scroll-behavior:auto!important}}
