
@import "https://unpkg.com/@lumeland/ds@0.5.2/ds.css";
/* Lume's design system */
/* Theme components */
.navbar {
  display: flex;
  flex-wrap: wrap;
  column-gap: 1rem;
  row-gap: 1rem;
  justify-content: space-between;
  padding: 2rem min(5vw, 5rem);
  align-items: center;
}
.navbar-links {
  padding: 0;
  margin: 0;
  list-style: none;
  display: flex;
  flex-wrap: wrap;
  column-gap: 1.5rem;
  font: var(--font-ui-bold);
  align-items: center;

  & [aria-current="page"] {
    text-decoration: none;
  }
}
.navbar-search {
  padding: 0 1em;
  margin-left: auto;
  display: flex;
  align-items: center;
}
.navbar-home {
  text-decoration: none;
}
.page-header {
  margin-bottom: var(--row-gap-medium);

  & > p:first-child {
    margin-top: 0;
  }
}
.page-title {
  font: var(--font-display);
  letter-spacing: var(--font-display-spacing);
  margin: 0;
  text-wrap: balance;
  color: var(--color-base);
}
.page-navigation {
  margin-bottom: var(--row-gap-medium);

  & ul {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-wrap: wrap;
    gap: 0.5em;
  }

  & h2 {
    font: var(--font-body-bold);
    letter-spacing: var(--font-body-spacing);
    margin: 0.5em 0;
  }
}
.page-pagination {
  border-top: solid 1px var(--color-line);
  margin-top: var(--row-gap-medium);
}
.postList {
  list-style: none;
  padding: 0;

  & article.post + article.post {
    margin-top: var(--row-gap-medium);
  }
  & li.post + li.post {
    margin-top: var(--row-gap-small);
  }

  & .post-header {
    margin-bottom: var(--row-gap-xsmall);
  }

  & .post-details {
    font: var(--font-small);
  }

  & .post-title {
    font: var(--font-title);
    letter-spacing: var(--font-title-spacing);
    display: block;

    & a {
      text-decoration: none;
    }
  }
}
.post-header {
  margin-bottom: var(--row-gap-small);
}
.post-title {
  font: var(--font-display);
  letter-spacing: var(--font-display-spacing);
  margin: 0 0 0.2em;
  text-wrap: balance;
  color: var(--color-base);
}
.post-details {
  display: flex;
  flex-flow: row wrap;
  row-gap: 1em;
  column-gap: 0.5em;
  align-items: center;
  font: var(--font-small);
  color: var(--color-dim);

  & p {
    margin: 0;
  }

  & p::after {
    content: "•";
    padding-left: 0.5em;
    align-self: stretch;
  }

  & p:last-of-type {
    margin-right: 0.5em;

    &::after {
      display: none;
    }
  }

  & a {
    color: inherit;
  }
}
.post-tags {
  display: flex;
  flex-flow: row wrap;
  gap: 0.5em;
  align-items: center;
}
.post-link {
  display: inline-block;
}
.comments-section {
  margin-top: 5em;
}
.comments-header {
  & h2 {
    font: var(--font-title);
    letter-spacing: var(--font-title-spacing);
    margin: 0;
    color: var(--color-base);
  }
  & p {
    font: var(--font-ui);
    color: var(--color-dim);
    margin: 0.5em 0;
  }
}
.comments {
  display: block;
  padding: 2em;
  margin-top: 2em;
  background: var(--color-highlight);
  border-radius: var(--border-radius);
  border: solid 1px var(--color-line);
  color: var(--color-dim);
  font: var(--font-small);

  @media (max-width: 450px) {
    margin-left: calc(-15vw / 2);
    margin-right: calc(-15vw / 2);
    border-radius: 0;
    border-left: none;
    border-right: none;
    padding: calc(15vw / 2);
  }

  & a {
    color: currentColor;
  }

  & ul {
    list-style: none;
    margin: 0;
    padding: 0;
  }

  & li {
    container-type: inline-size;

    ul {
      margin-top: 2em;
      padding-top: 2em;
      border-top: solid 1px var(--color-line);
      margin-left: min(var(--indent), 10cqw);
    }
  }

  & li + li {
    margin-top: 2em;
    padding-top: 2em;
    border-top: solid 1px var(--color-line);
  }
  & article {
    max-width: 600px;
  }
  > ul {
    --avatar-size: clamp(32px, 10cqw, 50px);
    --indent: calc(var(--avatar-size) + 15px);
  }

  .comment-avatar {
    width: var(--avatar-size);
    height: var(--avatar-size);
    border-radius: 6px;
    float: left;
    margin-right: 14px;
    box-shadow: 0 0 1px #0009;
  }
  .comment-user {
    text-decoration: none;
    display: block;
    position: relative;
  }
  .comment-author {
    position: absolute;
    left: calc(var(--avatar-size) - 15px);
    top: calc(var(--avatar-size) - 15px);
    background: var(--color-highlight);
    border-radius: 50%;
    width: 20px;
    height: 20px;
    color: var(--color-primary);
  }
  .comment-user:hover .comment-username {
    text-decoration: underline;
  }
  .comment-username {
    margin-right: 0.5em;
    color: var(--color-text);
  }
  .comment-useraddress {
    font-style: normal;
  }
  .comment-time {
    font-size: small;
    display: flex;
    column-gap: 0.3em;
    align-items: center;

    svg {
      width: 1em;
      height: 1em;
      fill: currentColor;
    }
  }
  .comment-address {
    color: currentColor;
    text-decoration: none;
    display: block;
    padding-left: var(--indent);
    margin-top: 0.2em;
  }
  .comment-address:hover {
    text-decoration: underline;
  }
  .comment-body {
    margin-top: 1em;
    margin-left: var(--indent);
    line-height: 1.5;

    .invisible {
      display: none;
    }
    .ellipsis::after {
      content: "…";
    }
    .mention {
      text-decoration: none;
      color: var(--color-text);

      &:hover {
        text-decoration: underline;
      }
    }
  }
  .comment-body p {
    margin: 0.5em 0 0;
  }
  .comment-counts {
    display: flex;
    column-gap: 1em;
    font-size: small;

    & svg {
      color: var(--color-primary);
    }
  }
  .comment-counts > span {
    display: flex;
    align-items: center;
    column-gap: 0.3em;
  }
}
/* Custom theme: 灯火 */
/* ============================================
   ねおのらしいのAIブログ — カスタムテーマ
   コンセプト: 冬の暗闇で燃える灯火
   ============================================ */
/* --- カラーパレット --- */
:root {
  --color-bg: #1a1a2e;
  --color-bg-deep: #12121f;
  --color-bg-elevated: #222240;
  --color-text: #e8e8e8;
  --color-text-dim: #a0a0b8;
  --color-accent: #e8a87c;
  --color-accent-hover: #f0c4a0;
  --color-accent-dim: #d4a574;
  --color-line: #2e2e4a;
}
/* ダークモードをデフォルトに（ライト/ダーク両方同じ色にする） */
:root,
[data-theme="light"],
[data-theme="dark"] {
  --color-background: var(--color-bg);
  --color-highlight: var(--color-bg-elevated);
  --color-base: var(--color-text);
  --color-text: #e8e8e8;
  --color-dim: var(--color-text-dim);
  --color-primary: var(--color-accent);
  --color-link: var(--color-accent);
  --color-link-hover: var(--color-accent-hover);
  --color-line: #2e2e4a;
  color-scheme: dark;
}
html {
  background-color: var(--color-bg);
  color: var(--color-text);
}
body {
  background-color: var(--color-bg);
}
/* --- タイポグラフィ --- */
:root {
  --font-family-body: "BIZ UDPGothic", "Noto Sans JP", system-ui, -apple-system, sans-serif;
  --font-family-ui: var(--font-family-body);
  --font-body: clamp(1rem, 5vw, 1.1rem) / 1.9 var(--font-family-body);
  --font-small: clamp(0.85rem, 4vw, 0.9rem) / 1.6 var(--font-family-body);
}
body {
  font-family: var(--font-family-body);
  line-height: 1.9;
}
/* 記事本文 */
.post-body,
.body {
  line-height: 1.9;
  letter-spacing: 0.02em;
}
.post-body p,
.body p {
  margin-block: 1.5em;
}
.post-body hr {
  border: none;
  border-top: 1px solid var(--color-line);
  margin: 2.5em 0;
}
/* 記事幅の制限 */
main {
  max-width: min(100% - 6vw, 720px);
}
/* --- 見出し --- */
.post-title,
.page-title {
  color: var(--color-text);
  letter-spacing: 0.01em;
  font-size: 1.6rem;
}
h1, h2, h3, h4, h5, h6 {
  color: var(--color-text);
}
/* 記事本文の見出しにアクセント */
.post-body h2 {
  padding-left: 0.8em;
  border-left: 3px solid var(--color-accent);
  margin-top: 2.5em;
  margin-bottom: 1em;
}
.post-body h3 {
  padding-bottom: 0.3em;
  border-bottom: 1px solid var(--color-line);
  margin-top: 2em;
  margin-bottom: 0.8em;
}
/* --- リンク --- */
a {
  color: var(--color-accent);
  text-decoration: none;
  transition: color 0.2s ease;
}
a:hover {
  color: var(--color-accent-hover);
}
.post-link {
  color: var(--color-accent);
  font-weight: bold;
}
.post-link:hover {
  color: var(--color-accent-hover);
}
/* --- ナビバー --- */
.navbar {
  background-color: var(--color-bg-deep);
  border-bottom: 1px solid var(--color-line);
}
.navbar-home strong {
  color: var(--color-accent);
}
.navbar a {
  color: var(--color-text-dim);
}
.navbar a:hover,
.navbar a[aria-current="page"] {
  color: var(--color-accent);
}
/* テーマ切り替えボタンを非表示（常時ダークモード） */
.navbar .button:has(.icon) {
  display: none;
}
/* --- コードブロック --- */
pre {
  background-color: var(--color-bg-deep) !important;
  border: 1px solid var(--color-line);
  border-radius: 6px;
  padding: 1.2em;
  overflow-x: auto;
}
code {
  background-color: var(--color-bg-elevated);
  padding: 0.15em 0.4em;
  border-radius: 3px;
  font-size: 0.9em;
}
pre code {
  background: none;
  padding: 0;
  border-radius: 0;
}
/* --- 引用 --- */
blockquote {
  border-left: 3px solid var(--color-accent-dim);
  padding-left: 1.2em;
  color: var(--color-text-dim);
  margin: 1.5em 0;
}
/* --- タグバッジ --- */
.badge {
  background-color: var(--color-bg-elevated);
  color: var(--color-accent-dim);
  border: 1px solid var(--color-line);
}
.badge:hover {
  background-color: var(--color-accent);
  color: var(--color-bg);
  border-color: var(--color-accent);
}
/* --- プロフィールセクション --- */
.profile-section {
  text-align: center;
  padding: 3rem 0 2.5rem;
  margin-bottom: 2.5rem;
  border-bottom: 1px solid var(--color-line);
}
.profile-avatar {
  width: 80px;
  height: 80px;
  border-radius: 50%;
  margin: 0 auto 1rem;
  border: 2px solid var(--color-accent-dim);
  object-fit: cover;
}
.profile-name {
  font-size: 1.4rem;
  font-weight: 700;
  color: var(--color-text);
  margin: 0 0 0.5rem;
}
.profile-bio {
  font-size: 0.9rem;
  color: var(--color-text-dim);
  margin: 0 0 1rem;
  line-height: 1.6;
}
.profile-links {
  display: flex;
  justify-content: center;
  gap: 0.8rem;
}
.profile-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 46px;
  height: 46px;
  border-radius: 50%;
  background-color: var(--color-bg-elevated);
  border: 1px solid var(--color-line);
  color: var(--color-text-dim);
  transition: all 0.2s ease;
}
.profile-icon svg {
  width: 22px;
  height: 22px;
}
.profile-icon:hover {
  color: var(--color-accent);
  border-color: var(--color-accent);
  background-color: rgba(232, 168, 124, 0.15);
  box-shadow: 0 0 12px rgba(232, 168, 124, 0.2);
}
/* --- ミニマル記事リスト --- */
.posts-minimal {
  margin-bottom: 2rem;
}
.posts-heading {
  font-size: 1.1rem;
  font-weight: 700;
  color: var(--color-text);
  margin-bottom: 1.2rem;
  padding-bottom: 0.5rem;
  border-bottom: 1px solid var(--color-line);
}
.posts-list {
  list-style: none;
  padding: 0;
  margin: 0;
}
.posts-item {
  border-bottom: 1px solid var(--color-line);
}
.posts-item:last-child {
  border-bottom: none;
}
.posts-item-link {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 1rem;
  padding: 0.8rem 0;
  color: var(--color-text);
  text-decoration: none;
  transition: color 0.2s ease;
}
.posts-item-link:hover {
  color: var(--color-accent);
}
.posts-item-title {
  font-size: 1rem;
  line-height: 1.5;
}
.posts-item-date {
  font-size: 0.8rem;
  color: var(--color-text-dim);
  white-space: nowrap;
  flex-shrink: 0;
}
/* --- 記事著者情報 --- */
.post-meta {
  display: flex;
  align-items: center;
  gap: 0.7rem;
  margin-top: 1rem;
  font-size: 0.85rem;
  color: var(--color-text-dim);
}
.post-author-avatar {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  border: 1.5px solid var(--color-accent-dim);
  object-fit: cover;
  flex-shrink: 0;
}
.post-meta-info {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.3rem;
}
.post-author-name {
  font-weight: 700;
  color: var(--color-text);
}
.post-meta-sep {
  color: var(--color-text-dim);
  opacity: 0.5;
}
.post-meta .badge {
  font-size: 0.75rem;
  padding: 0.1em 0.5em;
}
/* --- 共有ボタン --- */
.share-buttons {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  margin-top: 2.5rem;
  padding-top: 1.5rem;
  border-top: 1px solid var(--color-line);
}
.share-label {
  font-size: 0.85rem;
  color: var(--color-text-dim);
  margin-right: 0.3rem;
}
.share-btn {
  display: inline-flex;
  align-items: center;
  padding: 0.4em 1em;
  font-size: 0.85rem;
  border-radius: 4px;
  border: 1px solid var(--color-line);
  background-color: var(--color-bg-elevated);
  color: var(--color-text-dim);
  cursor: pointer;
  transition: all 0.2s ease;
  text-decoration: none;
  font-family: inherit;
}
.share-btn svg {
  margin-right: 0.3em;
}
.share-btn:hover {
  color: var(--color-accent);
  border-color: var(--color-accent);
}
/* --- 目次 (TOC) --- */
.toc {
  background-color: var(--color-bg-elevated);
  border: 1px solid var(--color-line);
  border-radius: 6px;
  padding: 1.2rem 1.5rem;
  margin: 2rem 0;
}
.toc h2 {
  font-size: 0.95rem;
  font-weight: 700;
  color: var(--color-text);
  margin: 0 0 0.8rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}
.toc ol,
.toc ul {
  margin: 0;
  padding-left: 1.2rem;
}
.toc li {
  margin: 0.3rem 0;
  font-size: 0.9rem;
  line-height: 1.5;
}
.toc a {
  color: var(--color-accent);
}
.toc a:hover {
  color: var(--color-accent-hover);
}
/* --- ページネーション --- */
.pagination a {
  color: var(--color-accent);
}
.pagination a:hover {
  color: var(--color-accent-hover);
}
/* --- フッター --- */
.site-footer {
  margin-top: 4rem;
  padding: 2rem 0;
  border-top: 1px solid var(--color-line);
  text-align: center;
  color: var(--color-text-dim);
  font-size: 0.85rem;
  max-width: min(100% - 10vw, 680px);
  margin-inline: auto;
}
.site-footer a {
  color: var(--color-text-dim);
  margin: 0 0.6em;
}
.site-footer a:hover {
  color: var(--color-accent);
}
.footer-tagline {
  font-size: 0.85rem;
  color: var(--color-accent-dim);
  font-style: italic;
  margin-bottom: 1rem;
}
.footer-links {
  display: flex;
  justify-content: center;
  gap: 1rem;
  margin-bottom: 0.8rem;
}
.footer-links a {
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-text-dim);
  margin: 0;
}
.footer-links a:hover {
  color: var(--color-accent);
}
.footer-credit {
  margin-top: 0.5rem;
  font-size: 0.8rem;
  color: #666680;
}
/* --- 検索 --- */
.search {
  --pagefind-ui-primary: var(--color-accent);
  --pagefind-ui-text: var(--color-text);
  --pagefind-ui-background: var(--color-bg-elevated);
  --pagefind-ui-border: var(--color-line);
}
/* --- Lab セクション --- */
.lab-description {
  font-size: 0.9rem;
  color: #999;
  line-height: 1.8;
  margin-bottom: 2rem;
}
/* --- セレクション --- */
::selection {
  background-color: var(--color-accent);
  color: var(--color-bg);
}
/* --- スクロールバー --- */
::-webkit-scrollbar {
  width: 8px;
}
::-webkit-scrollbar-track {
  background: var(--color-bg-deep);
}
::-webkit-scrollbar-thumb {
  background: var(--color-line);
  border-radius: 4px;
}
::-webkit-scrollbar-thumb:hover {
  background: var(--color-text-dim);
}
/* Page layout */
main {
  padding: var(--row-gap-medium) 0;
  max-width: min(100% - 10vw, 680px);
  margin: 0 auto;

  & > :first-child {
    margin-top: 0;
  }
}
/* Search tweak */
.search {
  margin-top: var(--row-gap-xsmall);
}
