:root{
  --bg:#0b0f14;
  --panel:#101826;
  --text:#e8eef6;
  --muted:#a8b3c4;
  --link:#7dd3fc;
  --border:rgba(255,255,255,.12);
  --shadow: 0 10px 30px rgba(0,0,0,.35);
}

*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--text);font-family:system-ui,-apple-system,"Segoe UI",Roboto,Helvetica,Arial,"Noto Sans JP","Hiragino Kaku Gothic ProN",Meiryo,sans-serif}
a{color:var(--link);text-decoration:none}
a:hover{text-decoration:underline}

.container{max-width:1060px;margin:0 auto;padding:24px}

.site-header{position:sticky;top:0;background:rgba(11,15,20,.86);backdrop-filter: blur(10px);border-bottom:1px solid var(--border);z-index:10}
.site-header .container{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:14px 24px}
.brand-title{font-weight:700;letter-spacing:.2px}
.brand-sub{color:var(--muted);font-size:12px;margin-top:4px}

.nav{display:flex;gap:14px;flex-wrap:wrap}
.nav a{font-size:13px;color:var(--text);opacity:.9}
.nav a:hover{opacity:1}

.hero{padding:24px 0}
.hero h1{margin:0 0 10px 0;font-size:28px;line-height:1.25}
.lead{color:var(--muted);max-width:820px;line-height:1.6;margin:0 0 14px 0}

.pill-row{display:flex;flex-wrap:wrap;gap:8px}
.pill{border:1px solid var(--border);background:rgba(255,255,255,.03);padding:6px 10px;border-radius:999px;font-size:12px;color:var(--muted)}

.card{background:var(--panel);border:1px solid var(--border);border-radius:14px;padding:18px 18px;box-shadow:var(--shadow);margin:16px 0}
.card h2{margin:0 0 10px 0;font-size:18px}
.card h3{margin:0 0 8px 0;font-size:15px}
.muted{color:var(--muted)}
.note{margin-top:10px;color:var(--muted);font-size:13px;line-height:1.6}

.grid-2{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
@media (max-width:780px){.grid-2{grid-template-columns:1fr}}

.list{margin:0;padding-left:18px;color:var(--muted);line-height:1.8}
.link{word-break:break-all}

.preview{margin-top:12px;border:1px solid var(--border);border-radius:12px;overflow:hidden;background:rgba(0,0,0,.25)}
.preview img{width:100%;height:auto;display:block}

.mono{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace}
.small{font-size:12px}

.site-footer{margin-top:20px;padding-top:12px;border-top:1px solid var(--border)}
/* Thumbnails */
    .thumb { margin:0; }
    .thumb-img{
      width:100%;
      height:auto;
      display:block;
      border-radius:12px;
      border:1px solid rgba(255,255,255,.12);
      cursor:zoom-in;
      background:rgba(0,0,0,.25);
    }
    .thumb-actions{ margin-top:8px; color:#a8b3c4; }
    .thumb-actions a{ font-size:12px; }
    .hero-thumb-wrap{ margin:14px 0 6px 0; }
    .hero-thumb{ max-width:860px; margin:0 auto; }
    .hero-thumb .muted{ font-size:12px; }

    /* Modal */
    .modal{ display:none; position:fixed; inset:0; z-index:9999; }
    .modal[aria-hidden="false"]{ display:block; }
    .modal-backdrop{ position:absolute; inset:0; background:rgba(0,0,0,.72); }
    .modal-panel{
      position:relative;
      max-width:min(1100px, 92vw);
      max-height:88vh;
      margin:6vh auto 0 auto;
      background:rgba(16,24,38,.98);
      border:1px solid rgba(255,255,255,.12);
      border-radius:14px;
      box-shadow: 0 10px 30px rgba(0,0,0,.35);
      padding:12px;
    }
    .modal-panel img{
      width:100%;
      height:auto;
      max-height:75vh;
      object-fit:contain;
      display:block;
      border-radius:10px;
    }
    .modal-close{
      position:absolute;
      top:8px;
      right:10px;
      width:38px;
      height:38px;
      border-radius:10px;
      border:1px solid rgba(255,255,255,.12);
      background:rgba(255,255,255,.06);
      color:#e8eef6;
      font-size:22px;
      cursor:pointer;
    }
    .modal-caption{
      margin-top:10px;
      color:#a8b3c4;
      font-size:13px;
      line-height:1.5;
    }

/* Mini thumbnails (for book covers) */
.thumb-mini{
  max-width: 80px;           /* ≒ 2cm */
}

.thumb-mini .thumb-img{
  cursor: zoom-in;
}

/* キャプションとリンクを小さく（任意） */
.thumb-mini figcaption,
.thumb-mini .thumb-actions{
  font-size: 11px;
  line-height: 1.25;
}

/* 余白も詰める（任意） */
.thumb-mini .thumb-actions{
  margin-top: 4px;
}


/* 横並び（文明設計論専用） */
.mini-row{
  display:flex;
  gap:20px;
  align-items:flex-start;
  flex-wrap:wrap;      /* 画面が狭い時は自然に折り返す */
}

/* サムネサイズ */
.thumb-mini{
  width:80px;          /* ≒2cm */
  flex:0 0 auto;
}

/* Author / Works: mini thumbnails aligned */
.mini-row{
  display:flex;
  gap:20px;
  align-items:flex-start;
  flex-wrap:wrap;
}

.thumb-mini{
  width:80px;          /* ≒2cm */
  flex:0 0 auto;
}

/* ここがズレ解消の核心：キャプション領域を固定 */
.thumb-mini figcaption{
  min-height: 2.4em;   /* 2行分を確保（JP/ENの差を吸収） */
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
  margin-bottom:6px;
}

/* ついでにリンク行も整える（任意） */
.thumb-mini .thumb-actions{
  margin-top:4px;
  text-align:center;
}



/* Author / Works thumbnails: perfectly aligned */
.mini-row{
  display:flex;
  gap:20px;
  align-items:flex-start;
  flex-wrap:wrap;
}

.thumb-card{
  display:flex;
  flex-direction:column;
  align-items:center;
}

.thumb-mini{
  width:80px;          /* ≒2cm */
  flex:0 0 auto;
}

/* ★ここが核心：キャプション領域を固定して、画像の開始位置を揃える */
.thumb-mini figcaption{
  height: 4.8em;       /* 3行ぶん確保（ENが3行なので） */
  display:flex;
  align-items:flex-end; /* 下揃え（文字が上に伸びても下端が揃う） */
  justify-content:center;
  text-align:center;
  margin:0 0 6px 0;
  line-height:1.2;
}

/* 画像は常にブロックで */
.thumb-mini .thumb-img{
  display:block;
}

/* 下の PDF・DOI も中央揃え */
.thumb-mini .thumb-actions{
  margin-top:4px;
  text-align:center;
}
