/* ============================================================
   タベブイア・アベラネダエ研究所
   基調カラー：タベブイア・アベラネダエの花色（ローズ〜マゼンタ）
   方針：落ち着き・余白・可読性。非営利・研究情報サイト。
   ============================================================ */
:root{
  --rose-900:#6f2c49;
  --rose-800:#883a5d;
  --rose-700:#a14a72;
  --rose-600:#b85d87;
  --rose-500:#c97aa0;   /* 花色アクセント */
  --rose-300:#e6b9cf;
  --rose-200:#f0d4e0;
  --rose-100:#f8e8ef;
  --blush:#fbf4f7;      /* ページ背景 */
  --cream:#fffdfc;
  --ink:#3b2b33;
  --ink-soft:#6d5c64;
  --ink-faint:#917e87;
  --leaf:#6f8f6a;       /* 葉の緑（自然のアクセント） */
  --leaf-soft:#e7eee4;
  --line:#eedbe5;
  --shadow:0 2px 14px rgba(111,44,73,.07);
  --shadow-lg:0 8px 30px rgba(111,44,73,.12);
  --radius:14px;
  --maxw:1080px;
  --serif:"Noto Serif JP",serif;
  --sans:"Noto Sans JP",-apple-system,"Segoe UI",sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;font-family:var(--sans);color:var(--ink);
  background:var(--blush);line-height:1.85;font-size:16px;
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3,h4{font-family:var(--serif);font-weight:600;line-height:1.5;color:var(--rose-900)}
a{color:var(--rose-700);text-decoration:none}
a:hover{text-decoration:underline}
img{max-width:100%}
.container{max-width:var(--maxw);margin:0 auto;padding:0 22px}
.narrow{max-width:760px}

/* ---------- ヘッダー ---------- */
.site-header{
  position:sticky;top:0;z-index:50;background:rgba(255,253,252,.92);
  backdrop-filter:blur(8px);border-bottom:1px solid var(--line);
}
.site-header .container{display:flex;align-items:center;justify-content:space-between;gap:16px;padding-top:12px;padding-bottom:12px}
.brand{display:flex;align-items:center;gap:11px;font-family:var(--serif)}
.brand .mark{width:34px;height:34px;flex:0 0 auto}
.brand b{font-size:1.06rem;color:var(--rose-900);font-weight:600;letter-spacing:.02em}
.brand span{display:block;font-size:.7rem;color:var(--ink-faint);font-family:var(--sans);letter-spacing:.08em}
.nav{display:flex;gap:6px;align-items:center;flex-wrap:wrap}
.nav a{
  color:var(--ink-soft);padding:7px 13px;border-radius:999px;font-size:.92rem;font-weight:500;
}
.nav a:hover{background:var(--rose-100);color:var(--rose-800);text-decoration:none}
.nav a.active{background:var(--rose-700);color:#fff}
.nav-toggle{display:none;background:none;border:1px solid var(--line);border-radius:9px;padding:6px 10px;font-size:1.1rem;cursor:pointer;color:var(--rose-800)}

/* ---------- 画像・写真 ---------- */
.hero-inner{display:grid;grid-template-columns:1.05fr .95fr;gap:44px;align-items:center}
.hero-photo{margin:0}
.hero-photo img{width:100%;height:auto;border-radius:18px;box-shadow:var(--shadow-lg);display:block;aspect-ratio:4/3;object-fit:cover}
.hero-photo figcaption{margin-top:9px;font-size:.78rem;color:var(--ink-faint);line-height:1.65}
.credit{color:var(--ink-faint);font-size:.92em}
.credit a{color:var(--ink-faint);text-decoration:underline}
figure.photo{margin:1.6em 0}
figure.photo img{width:100%;height:auto;border-radius:14px;box-shadow:var(--shadow);display:block}
figure.photo figcaption{margin-top:8px;font-size:.82rem;color:var(--ink-soft);line-height:1.65}
.fig-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin:1.6em 0}
.fig-grid figure.photo{margin:0}
.fig-grid figure.photo img{aspect-ratio:4/3;object-fit:cover}
.credits-box{background:var(--cream);border:1px solid var(--line);border-radius:12px;padding:16px 20px;margin:34px 0 0;font-size:.82rem;color:var(--ink-soft)}
.credits-box b{color:var(--rose-800)}
.credits-box ul{margin:.5em 0 0;padding-left:1.2em}
.credits-box li{margin:.3em 0}
.credits-box a{color:var(--ink-soft);text-decoration:underline}

/* ---------- ヒーロー ---------- */
.hero{
  background:
    radial-gradient(1100px 380px at 78% -8%, var(--rose-200), transparent 60%),
    linear-gradient(180deg,var(--rose-100),var(--blush));
  border-bottom:1px solid var(--line);
}
.hero .container{padding-top:64px;padding-bottom:60px}
.hero .eyebrow{color:var(--rose-600);font-weight:600;letter-spacing:.14em;font-size:.78rem;margin:0 0 14px}
.hero h1{font-size:2.35rem;margin:.1em 0 .35em;line-height:1.4}
.hero p.lead{font-size:1.08rem;color:var(--ink-soft);max-width:640px;margin:0 0 26px}
.hero-actions{display:flex;gap:12px;flex-wrap:wrap}

/* ---------- ボタン ---------- */
.btn{
  display:inline-block;padding:11px 22px;border-radius:999px;font-weight:600;font-size:.95rem;
  border:1.5px solid transparent;cursor:pointer;transition:.18s;
}
.btn-primary{background:var(--rose-700);color:#fff}
.btn-primary:hover{background:var(--rose-800);text-decoration:none}
.btn-ghost{background:#fff;color:var(--rose-800);border-color:var(--rose-300)}
.btn-ghost:hover{background:var(--rose-100);text-decoration:none}

/* ---------- セクション ---------- */
section.block{padding:56px 0}
.section-head{margin-bottom:30px}
.section-head .eyebrow{color:var(--rose-600);font-weight:600;letter-spacing:.12em;font-size:.76rem;margin:0 0 8px}
.section-head h2{font-size:1.7rem;margin:0}
.section-head p{color:var(--ink-soft);margin:.5em 0 0}

/* ---------- カード ---------- */
.card-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:20px}
.card{
  background:var(--cream);border:1px solid var(--line);border-radius:var(--radius);
  padding:24px 22px;box-shadow:var(--shadow);transition:.18s;
}
.card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}
.card h3{margin:.1em 0 .4em;font-size:1.12rem}
.card p{color:var(--ink-soft);margin:0;font-size:.95rem}
.card .ico{font-size:1.6rem;line-height:1;margin-bottom:6px;display:block}

/* ---------- 統計バッジ ---------- */
.stats{display:flex;gap:34px;flex-wrap:wrap;margin-top:30px}
.stat b{display:block;font-family:var(--serif);font-size:2rem;color:var(--rose-700);line-height:1}
.stat span{color:var(--ink-faint);font-size:.85rem}

/* ---------- 検索・フィルタ（論文一覧） ---------- */
.toolbar{
  background:var(--blush);
  padding:4px 0 14px;border-bottom:1px solid var(--line);margin-bottom:24px;
}
.search-box{position:relative;max-width:560px}
.search-box input{
  width:100%;padding:14px 16px 14px 44px;border:1.5px solid var(--rose-300);border-radius:999px;
  font-size:1rem;font-family:var(--sans);background:#fff;color:var(--ink);
}
.search-box input:focus{outline:none;border-color:var(--rose-600);box-shadow:0 0 0 4px var(--rose-100)}
.search-box .si{position:absolute;left:16px;top:50%;transform:translateY(-50%);color:var(--rose-500)}
.chips{display:flex;gap:8px;flex-wrap:wrap;margin-top:14px}
.chip{
  border:1.5px solid var(--rose-300);background:#fff;color:var(--rose-800);
  padding:6px 14px;border-radius:999px;font-size:.84rem;cursor:pointer;transition:.15s;font-weight:500;
}
.chip:hover{background:var(--rose-100)}
.chip.active{background:var(--rose-700);color:#fff;border-color:var(--rose-700)}
.chip .n{opacity:.7;font-size:.78em;margin-left:4px}
.result-count{color:var(--ink-faint);font-size:.88rem;margin:6px 0 18px}

/* ---------- 論文リスト ---------- */
.paper{
  background:var(--cream);border:1px solid var(--line);border-left:4px solid var(--rose-300);
  border-radius:10px;padding:20px 22px;margin-bottom:16px;box-shadow:var(--shadow);transition:.15s;
}
.paper:hover{border-left-color:var(--rose-600)}
.paper .meta{display:flex;gap:10px;flex-wrap:wrap;align-items:center;margin-bottom:8px;font-size:.78rem}
.tag{padding:3px 10px;border-radius:999px;font-weight:600;font-size:.74rem}
.tag-cat{background:var(--rose-100);color:var(--rose-800)}
.tag-year{background:#f1ece9;color:var(--ink-soft)}
.tag-ja{background:var(--leaf-soft);color:#456b3f}
.tag-oa{background:#eaf3ff;color:#2c5aa0}
.tag-type{background:#fff;border:1px solid var(--line);color:var(--ink-faint)}
.paper h3{font-size:1.08rem;margin:.1em 0 .25em;line-height:1.6}
.paper .title-en{font-size:.92rem;color:var(--ink-faint);font-style:italic;margin:0 0 .4em}
.paper .authors{font-size:.86rem;color:var(--ink-soft);margin:0 0 .2em}
.paper .journal{font-size:.86rem;color:var(--ink-faint);margin:0 0 .6em}
.paper .abs{
  font-size:1.02rem;line-height:2.0;color:var(--ink);margin:0;
  max-height:0;overflow:hidden;transition:max-height .4s ease;
}
.paper.open .abs{
  max-height:none;margin:.9em 0 .2em;padding:16px 18px;
  background:var(--blush);border-radius:10px;border:1px solid var(--line);
}
.paper .links{display:flex;gap:8px;flex-wrap:wrap;margin-top:14px}
.paper .links a{
  font-size:.8rem;padding:5px 12px;border:1px solid var(--rose-300);border-radius:8px;
  color:var(--rose-800);background:#fff;font-weight:600;
}
.paper .links a:hover{background:var(--rose-100);text-decoration:none}
.toggle-abs{background:none;border:none;color:var(--rose-700);cursor:pointer;font-size:.82rem;font-weight:600;padding:0;margin-top:6px;font-family:var(--sans)}
.no-result{text-align:center;color:var(--ink-faint);padding:50px 0}

/* ---------- 解説（about）ページ ---------- */
.prose{max-width:760px}
.prose h2{font-size:1.55rem;margin:1.8em 0 .5em;padding-bottom:.3em;border-bottom:2px solid var(--rose-200)}
.prose h3{font-size:1.2rem;margin:1.4em 0 .4em;color:var(--rose-800)}
.prose p{margin:.8em 0}
.prose ul{padding-left:1.3em}
.prose li{margin:.35em 0}
.callout{
  background:var(--rose-100);border-left:4px solid var(--rose-500);border-radius:0 10px 10px 0;
  padding:16px 20px;margin:1.4em 0;font-size:.95rem;
}
.callout.leaf{background:var(--leaf-soft);border-left-color:var(--leaf)}
.callout b{color:var(--rose-900)}
.note{font-size:.85rem;color:var(--ink-faint)}
.toc{background:var(--cream);border:1px solid var(--line);border-radius:12px;padding:18px 22px;margin:0 0 30px}
.toc b{display:block;margin-bottom:8px;color:var(--rose-800);font-family:var(--serif)}
.toc ol{margin:0;padding-left:1.3em}
.toc a{color:var(--ink-soft)}

/* ---------- ブログ ---------- */
.post-list{display:grid;gap:18px}
.post-card{
  background:var(--cream);border:1px solid var(--line);border-radius:var(--radius);
  padding:22px 24px;box-shadow:var(--shadow);transition:.18s;
}
.post-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}
.post-card .date{color:var(--rose-600);font-size:.8rem;font-weight:600;letter-spacing:.04em}
.post-card h3{margin:.3em 0 .35em;font-size:1.2rem}
.post-card p{color:var(--ink-soft);margin:0;font-size:.93rem}
.post-card .cat{display:inline-block;margin-top:10px;font-size:.74rem;background:var(--rose-100);color:var(--rose-800);padding:3px 10px;border-radius:999px;font-weight:600}

/* 記事本文 */
.article{max-width:740px}
.article .date{color:var(--rose-600);font-weight:600;font-size:.85rem}
.article h1{font-size:1.9rem;margin:.2em 0 .4em;line-height:1.45}
.article .lead{font-size:1.05rem;color:var(--ink-soft);background:var(--rose-100);padding:16px 20px;border-radius:12px;margin:1.2em 0}
.article h2{font-size:1.4rem;margin:1.6em 0 .4em;border-bottom:2px solid var(--rose-200);padding-bottom:.25em}
.article p{margin:.85em 0}
.article .source{background:var(--cream);border:1px solid var(--line);border-radius:12px;padding:18px 20px;margin:2em 0;font-size:.9rem}
.article .source b{color:var(--rose-800)}
.article .backlink{margin-top:30px}

/* ---------- フッター ---------- */
.site-footer{background:var(--rose-900);color:#f3dde7;margin-top:60px;padding:46px 0 30px;font-size:.9rem}
.site-footer a{color:#f3dde7;text-decoration:underline}
.site-footer .cols{display:grid;grid-template-columns:2fr 1fr 1fr;gap:30px}
.site-footer h4{color:#fff;font-size:.95rem;margin:0 0 12px}
.site-footer ul{list-style:none;padding:0;margin:0}
.site-footer li{margin:.3em 0}
.site-footer .fine{margin-top:30px;padding-top:18px;border-top:1px solid rgba(255,255,255,.18);color:#d9b9c9;font-size:.8rem;line-height:1.7}

/* ---------- 免責 ---------- */
.disclaimer{background:#fff6f0;border:1px solid #f0d9c8;border-radius:12px;padding:16px 20px;font-size:.85rem;color:#7a5a45;margin:24px 0}
.disclaimer b{color:#9a5a2e}

/* ---------- レスポンシブ ---------- */
@media(max-width:760px){
  .hero h1{font-size:1.8rem}
  .hero-inner{grid-template-columns:1fr;gap:26px}
  .fig-grid{grid-template-columns:1fr}
  .nav{display:none;position:absolute;top:100%;left:0;right:0;background:var(--cream);
    flex-direction:column;align-items:stretch;padding:10px;border-bottom:1px solid var(--line);box-shadow:var(--shadow)}
  .nav.show{display:flex}
  .nav a{padding:12px 14px}
  .nav-toggle{display:block}
  .site-footer .cols{grid-template-columns:1fr;gap:22px}
  .stats{gap:24px}
  .paper{padding:18px 16px}
  .paper .abs{font-size:1.05rem;line-height:2.05}
  .paper.open .abs{padding:14px 14px}
}
