/* /src/blog/assets/blog.css */

/* ベース */
.blog-body {
    margin: 0;
    font-family: system-ui, -apple-system, BlinkMacSystemFont, "Hiragino Sans", "Meiryo", sans-serif;
    background: #f4f5fb;
    color: #111827;
  }
  
  /* ヘッダー */
  .blog-header {
    background: linear-gradient(120deg, #7dd3fc, #a5b4fc);
    color: #0f172a;
    padding: 20px 16px 24px;
  }
  
  .blog-header-inner {
    max-width: 960px;
    margin: 0 auto;
  }
  
  .blog-eyebrow {
    font-size: 0.75rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    opacity: 0.8;
    margin-bottom: 4px;
  }
  
  .blog-title {
    margin: 0;
    font-size: clamp(1.7rem, 4vw, 2.4rem);
    letter-spacing: 0.08em;
  }
  
  .blog-sub {
    margin: 8px 0 14px;
    font-size: 0.9rem;
    opacity: 0.9;
  }
  
  .blog-header-links {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
  }
  
  .blog-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 6px 14px;
    border-radius: 999px;
    font-size: 0.8rem;
    text-decoration: none;
    color: #0f172a;
    border: 1px solid rgba(15, 23, 42, 0.08);
    background: rgba(255, 255, 255, 0.7);
    backdrop-filter: blur(8px);
  }
  
  .blog-link--primary {
    background: #0f172a;
    color: #f9fafb;
  }
  
  /* メインレイアウト */
  .blog-main {
    max-width: 960px;
    margin: 16px auto 40px;
    padding: 0 16px;
  }
  
  /* 空メッセージ */
  .blog-empty {
    margin-top: 24px;
    font-size: 0.95rem;
    color: #4b5563;
  }
  
  /* 一覧のカード */
  .blog-list {
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    gap: 14px;
    margin-top: 16px;
  }
  
  .blog-card {
    display: flex;
    gap: 12px;
    padding: 10px 12px;
    border-radius: 18px;
    background: #ffffff;
    box-shadow:
      0 8px 18px rgba(15, 23, 42, 0.04),
      0 0 0 1px rgba(15, 23, 42, 0.03);
  }
  
  .blog-card-thumb {
    flex: 0 0 96px;
    border-radius: 14px;
    overflow: hidden;
  }
  
  .blog-card-thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
  }
  
  .blog-card-body {
    flex: 1;
    min-width: 0;
  }
  
  .blog-card-header {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 0.8rem;
    color: #6b7280;
  }
  
  .blog-card-date {
    margin: 0;
  }
  
  .blog-card-mood {
    display: inline-flex;
    align-items: center;
    padding: 2px 8px;
    border-radius: 999px;
    background: #eef2ff;
    color: #4338ca;
    font-size: 0.75rem;
  }
  
  .blog-card-title {
    margin: 4px 0 4px;
    font-size: 1rem;
  }
  
  .blog-card-title a {
    text-decoration: none;
    color: inherit;
  }
  
  .blog-lock {
    font-size: 0.85rem;
    margin-left: 4px;
  }
  
  .blog-card-excerpt {
    margin: 0;
    font-size: 0.9rem;
    color: #4b5563;
  }
  
  .blog-card-more {
    margin: 6px 0 0;
    font-size: 0.8rem;
  }
  
  .blog-card-more a {
    text-decoration: none;
    color: #2563eb;
  }
  
  /* 記事詳細 */
  .blog-article {
    margin-top: 18px;
    padding: 16px 16px 20px;
    border-radius: 20px;
    background: #ffffff;
    box-shadow:
      0 10px 24px rgba(15, 23, 42, 0.06),
      0 0 0 1px rgba(15, 23, 42, 0.03);
  }
  
  .blog-article-header {
    margin-bottom: 12px;
  }
  
  .blog-article-date {
    font-size: 0.9rem;
    color: #6b7280;
    margin: 0 0 4px;
  }
  
  .blog-article-lock {
    display: inline-flex;
    align-items: center;
    margin-left: 8px;
    padding: 1px 8px;
    border-radius: 999px;
    background: #fef3c7;
    color: #92400e;
    font-size: 0.75rem;
  }
  
  .blog-article-mood {
    display: inline-flex;
    align-items: center;
    padding: 2px 10px;
    border-radius: 999px;
    background: #eef2ff;
    color: #4338ca;
    font-size: 0.8rem;
  }
  
  .blog-article-title {
    margin: 6px 0 0;
    font-size: 1.3rem;
  }
  
  /* 画像 */
  .blog-article-images {
    margin: 14px 0 10px;
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    gap: 8px;
  }
  
  .blog-image-figure {
    margin: 0;
    border-radius: 14px;
    overflow: hidden;
  }
  
  .blog-image-figure img {
    width: 100%;
    display: block;
  }
  
  /* 本文 */
  .blog-article-body {
    margin-top: 10px;
    font-size: 0.98rem;
    line-height: 1.8;
    color: #374151;
  }
  
  .blog-article-body h2 {
    font-size: 1.05rem;
    margin: 12px 0 6px;
    padding-bottom: 2px;
    border-bottom: 1px solid #e5e7eb;
  }
  
  .blog-article-body strong {
    font-weight: 600;
  }
  
  .blog-article-body code {
    font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
    background: #f3f4f6;
    padding: 0 4px;
    border-radius: 4px;
    font-size: 0.9em;
  }
  
  /* ロック画面 */
  .blog-lock-box {
    margin-top: 16px;
    padding: 14px 14px 16px;
    border-radius: 14px;
    background: #fefce8;
    border: 1px solid #facc15;
    font-size: 0.9rem;
  }
  
  .blog-lock-error {
    color: #b91c1c;
    margin: 4px 0 8px;
    font-size: 0.85rem;
  }
  
  .blog-lock-form {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 6px;
  }
  
  .blog-lock-form input[type="password"] {
    flex: 1;
    min-width: 180px;
    padding: 6px 8px;
    border-radius: 8px;
    border: 1px solid #d1d5db;
  }
  
  .blog-lock-form button {
    padding: 6px 14px;
    border-radius: 999px;
    border: none;
    background: #0f172a;
    color: #f9fafb;
    cursor: pointer;
  }
  
  /* エディタ */
  .blog-editor {
    margin-top: 18px;
    padding: 16px 16px 20px;
    border-radius: 20px;
    background: #ffffff;
    box-shadow:
      0 10px 24px rgba(15, 23, 42, 0.06),
      0 0 0 1px rgba(15, 23, 42, 0.03);
  }
  
  .blog-error {
    margin: 0 0 12px;
    padding: 8px 10px;
    border-radius: 10px;
    background: #fef2f2;
    color: #b91c1c;
    font-size: 0.9rem;
  }
  
  .blog-form {
    display: flex;
    flex-direction: column;
    gap: 14px;
  }
  
  .blog-form-row label {
    display: block;
    font-size: 0.9rem;
    margin-bottom: 4px;
    font-weight: 600;
  }
  
  .blog-form-label-inline {
    font-size: 0.9rem;
    display: flex;
    align-items: center;
    gap: 6px;
  }
  
  .blog-form-row input[type="text"],
  .blog-form-row input[type="password"],
  .blog-form-row input[type="file"],
  .blog-form-row textarea {
    width: 100%;
    box-sizing: border-box;
    padding: 8px 10px;
    border-radius: 8px;
    border: 1px solid #d1d5db;
    font-size: 0.9rem;
    font-family: inherit;
  }
  
  .blog-form-row textarea {
    resize: vertical;
  }
  
  .blog-help {
    margin: 4px 0 0;
    font-size: 0.8rem;
    color: #6b7280;
  }
  
  /* ツールバー */
  .blog-editor-toolbar {
    display: flex;
    flex-wrap: wrap;
    gap: 4px;
    margin-bottom: 6px;
  }
  
  .blog-editor-toolbar button {
    border: none;
    border-radius: 999px;
    padding: 4px 10px;
    font-size: 0.78rem;
    background: #f3f4f6;
    color: #374151;
    cursor: pointer;
  }
  
  /* プレビュー */
  .blog-preview-toggle {
    margin-top: 6px;
    font-size: 0.83rem;
    color: #4b5563;
  }
  
  .blog-preview {
    margin-top: 8px;
    padding: 10px 12px;
    border-radius: 10px;
    background: #f9fafb;
    border: 1px dashed #d1d5db;
    font-size: 0.9rem;
    line-height: 1.7;
    display: none;
  }
  
  .blog-preview h2 {
    font-size: 1.02rem;
    margin: 6px 0 4px;
    padding-bottom: 2px;
    border-bottom: 1px solid #e5e7eb;
  }
  
  .blog-preview strong {
    font-weight: 600;
  }
  
  /* 既存画像の一覧 */
  .blog-edit-images {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 6px;
  }
  
  .blog-edit-image-item {
    display: inline-flex;
    flex-direction: column;
    gap: 4px;
    font-size: 0.78rem;
    color: #4b5563;
  }
  
  .blog-edit-image-item img {
    width: 120px;
    height: 80px;
    object-fit: cover;
    border-radius: 8px;
    display: block;
  }
  
  .blog-edit-image-checkbox {
    display: inline-flex;
    align-items: center;
    gap: 4px;
  }
  
  /* 送信ボタン */
  .blog-form-actions {
    margin-top: 4px;
  }
  
  .blog-submit-btn {
    padding: 9px 18px;
    border-radius: 999px;
    border: none;
    background: linear-gradient(130deg, #0ea5e9, #6366f1);
    color: #f9fafb;
    font-size: 0.9rem;
    cursor: pointer;
  }
  
  /* レスポンシブ */
  @media (min-width: 768px) {
    .blog-card {
      padding: 12px 14px;
    }
  
    .blog-article-images {
      grid-template-columns: repeat(2, minmax(0, 1fr));
    }
  
    .blog-edit-image-item img {
      width: 140px;
      height: 90px;
    }
  }
  .blog-btn--danger {
    background: #b91c1c;
    border-color: #7f1d1d;
  }
  .blog-btn--danger:hover {
    background: #dc2626;
    border-color: #991b1b;
  }
  
  .blog-flash {
    padding: 8px 12px;
    margin-bottom: 12px;
    border-radius: 4px;
    background: #ecfdf5;
    color: #166534;
    font-size: 0.9rem;
  }
  .blog-flash--error {
    background: #fef2f2;
    color: #b91c1c;
  }
  