/* ───────────────────────────────────────────────────────────
   Compora Labs — blog article page (supplements works/detail.css)
   Pass 6B: blog 世界 = #ecc85a / #ef9a4d / #f2b56a (琥珀〜橙)
   works/detail.css が先に読まれている前提でオーバーライドのみ記述。
   ─────────────────────────────────────────────────────────── */

/* ── blog 色世界: --w-a/--w-b/--w-c を amber に上書き ─────── */
:root{
  --w-a:#ecc85a;--w-b:#ef9a4d;--w-c:#f2b56a;
  --w-grad:linear-gradient(110deg,var(--w-a),var(--w-b));
  --w-grad3:linear-gradient(110deg,var(--w-a),var(--w-b),var(--w-c));
}

/* bg オーバーライド: amber グロー */
.bg{
  background:
    radial-gradient(130% 100% at 28% 20%, rgba(236,200,90,.12), transparent 58%),
    radial-gradient(120% 90% at 78% 70%, rgba(239,154,77,.11), transparent 58%),
    radial-gradient(110% 80% at 50% 110%, rgba(242,181,106,.08), transparent 60%),
    #05060c !important}

/* bg::before DNA ストランド: amber recolor (ページ独自のヒーロー SVG を使う) */
.bg::before{display:none}

/* ── スクロールプログレスバー: amber ────────────────────────── */
.art-progress{position:fixed;left:0;top:0;height:3px;width:100%;z-index:60;transform-origin:0 50%;transform:scaleX(0);
  background:var(--w-grad);box-shadow:0 0 14px rgba(236,200,90,.55)}

/* ── badge: amber ────────────────────────────────────────────── */
.badge{
  background:rgba(236,200,90,.10) !important;
  border-color:rgba(236,200,90,.25) !important}
.badge .dot{background:var(--w-grad) !important;
  box-shadow:0 0 10px 1px var(--w-a) !important}

/* ── eyebrow dot: amber ──────────────────────────────────────── */
.eyebrow .dot{background:var(--w-grad) !important;box-shadow:0 0 10px 1px var(--w-a) !important}

/* ── nav cta: amber ──────────────────────────────────────────── */
.nav-cta{background:var(--w-grad) !important}

/* ── footer ──────────────────────────────────────────────────── */
.foot-back{border-color:rgba(236,200,90,.25) !important}
.foot-back:hover{box-shadow:0 8px 30px -12px var(--w-a) !important}
.foot .mark b{background:var(--w-grad) !important;-webkit-background-clip:text;background-clip:text;color:transparent}

/* ── article layout ─────────────────────────────────────────── */
.article-wrap{max-width:820px;margin:0 auto;padding:0 22px}

/* ── hero ─────────────────────────────────────────────────────── */
.art-hero{padding-top:clamp(40px,7vh,72px);padding-bottom:6px;position:relative;overflow:hidden}
.art-tag{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-tech);font-weight:600;font-size:12px;
  letter-spacing:.14em;text-transform:uppercase;color:var(--ink);
  background:rgba(236,200,90,.10);border:1px solid rgba(236,200,90,.25);
  padding:6px 14px;border-radius:999px}
.art-title{font-family:var(--font-jp);font-weight:700;font-size:clamp(25px,4.4vw,40px);line-height:1.45;margin:22px 0 16px;color:var(--ink);text-wrap:pretty}
.art-meta{display:flex;flex-wrap:wrap;gap:12px;align-items:center;font-family:var(--font-tech);font-size:13px;color:var(--ink-faint)}
.art-meta .sep{opacity:.45}
.art-eyecatch{margin:30px 0 6px;border-radius:20px;overflow:hidden;
  box-shadow:0 30px 70px -44px rgba(0,0,0,.9)}
.art-eyecatch img{width:100%;height:auto;display:block}

/* ── body typography (サイズ・行間変更禁止) ──────────────────── */
.article{font-family:var(--font-jp);color:var(--ink-soft);font-size:clamp(16px,1.9vw,17.5px);line-height:2.05;padding-top:22px;padding-bottom:10px}
.article p{margin:0 0 26px;text-wrap:pretty}
.article strong{color:var(--ink);font-weight:700}
.article h2{font-family:var(--font-jp);font-weight:700;font-size:clamp(21px,3vw,28px);line-height:1.5;color:var(--ink);
  margin:56px 0 20px;padding-top:18px;position:relative}
.article h2::before{content:"";position:absolute;left:0;top:0;width:46px;height:3px;border-radius:3px;background:var(--w-grad)}
.article h3{font-family:var(--font-jp);font-weight:700;font-size:clamp(18px,2.2vw,21px);line-height:1.55;color:var(--ink);margin:40px 0 14px}
.article ul,.article ol{margin:0 0 26px;padding-left:1.4em}
.article li{margin:0 0 11px;line-height:1.95}
.article ol{counter-reset:li}
/* blockquote: void-panel 様式 */
.article blockquote{
  margin:30px 0;padding:20px 26px;border-radius:14px;
  background:rgba(8,8,14,.55);
  -webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);
  position:relative;overflow:hidden;
  border:1px solid rgba(236,200,90,.18)}
.article blockquote::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--w-grad)}
.article blockquote p{margin:0 0 8px;color:var(--ink);font-weight:700;font-size:clamp(16.5px,2vw,19px);line-height:1.85}
.article blockquote p:last-child{margin:0}

/* ── figures ─────────────────────────────────────────────────── */
.article figure{margin:36px 0}
.article figure img{width:100%;height:auto;display:block;border-radius:16px;border:1px solid rgba(236,200,90,.18);background:#fff}
.article figcaption{font-family:var(--font-jp);font-size:13.5px;color:var(--ink-faint);line-height:1.85;margin-top:13px;text-align:center;text-wrap:pretty}
.article hr{border:0;height:1px;background:var(--line);margin:50px 0}

/* ── reference boxes ─────────────────────────────────────────── */
.art-box{margin:14px 0 26px;padding:22px 24px;border-radius:16px;
  background:rgba(8,8,14,.55);border:1px solid rgba(236,200,90,.18)}
.art-box ul{margin:0;padding-left:1.25em}
.art-box li{margin:0 0 12px}
.art-box li:last-child{margin:0}
.art-note{font-size:13.5px;color:var(--ink-faint);line-height:1.9;margin:14px 0 0}

/* ── CTA block: void-panel 様式 ────────────────────────────── */
.art-cta{
  margin:54px 0 8px;padding:clamp(26px,4vw,40px);border-radius:22px;
  text-align:center;position:relative;overflow:hidden;
  background:rgba(8,8,14,.55);
  -webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);
  border:1px solid rgba(236,200,90,.22);
  box-shadow:0 28px 70px -50px rgba(0,0,0,.9)}
.art-cta::before{content:"";position:absolute;left:0;top:0;right:0;height:3px;background:var(--w-grad)}
/* HUD コーナー */
.art-cta::after{
  content:"";position:absolute;
  top:8px;right:8px;
  width:14px;height:14px;
  border-top:1.5px solid var(--w-a);
  border-right:1.5px solid var(--w-a);
  border-top-right-radius:4px;
  opacity:.5;pointer-events:none}
.art-cta p{font-family:var(--font-jp);font-size:15.5px;color:var(--ink-soft);margin:0 auto 22px;line-height:1.95;max-width:52ch}
.art-sign{font-family:var(--font-tech);font-size:13px;color:var(--ink-faint);margin:34px 0 0;text-align:right}

/* CTA btn: amber */
.art-cta .btn-primary{background:var(--w-grad);color:#0b0a10}
.art-cta .btn-primary:hover{box-shadow:0 14px 40px -12px var(--w-a)}

@media(max-width:560px){.article{font-size:16px;line-height:2}.art-title{font-size:24px}}

/* ── scroll reveal ──────────────────────────────────────────── */
.js-reveal .art-hero > *:not(.art-helix-bg),.js-reveal .article > *{opacity:0;transform:perspective(900px) translateY(52px) rotateX(10deg);transform-origin:50% 100%;
  transition:opacity 1.05s cubic-bezier(.2,.7,.2,1),transform 1.05s cubic-bezier(.2,.7,.2,1)}
.js-reveal .art-hero > *:not(.art-helix-bg).in,.js-reveal .article > *.in{opacity:1;transform:perspective(900px) translateY(0) rotateX(0)}

/* 章見出し h2: amber 下線 */
.js-reveal .article h2::before{transform:scaleX(0);transform-origin:0 50%;transition:transform .8s .15s cubic-bezier(.2,.7,.2,1)}
.js-reveal .article h2.in::before{transform:scaleX(1)}

/* 記事タイトル h1 の下に amber 棒線 */
.art-title::after{content:"";display:block;height:4px;width:170px;max-width:62%;margin-top:18px;border-radius:4px;background:var(--w-grad);transform-origin:0 50%}
.js-reveal .art-title::after{transform:scaleX(0);transition:transform .9s .2s cubic-bezier(.2,.7,.2,1)}
.js-reveal .art-title.in::after{transform:scaleX(1)}

/* 本文の太字: amber マーカー */
.article strong{background-image:var(--w-grad);background-repeat:no-repeat;background-position:left bottom;background-size:100% .16em;padding:0 .04em .05em;border-radius:1px}
.js-reveal .article strong{background-size:0% .16em;transition:background-size .9s .2s cubic-bezier(.2,.7,.2,1)}
.js-reveal .article > *.in strong{background-size:100% .16em}

/* 図: ホバーで浮く */
.article figure img{transition:transform .5s cubic-bezier(.2,.7,.2,1),box-shadow .5s}
.article figure:hover img{transform:translateY(-5px);box-shadow:0 28px 56px -30px rgba(0,0,0,.85)}

/* ═══════════════════════════════════════════════════════════
   §B  Helix Spine — ブログ記事装飾
   ═══════════════════════════════════════════════════════════ */

/* ── §B-1: ヒーロー DNA ストランド装飾 (amber recolor) ──── */
.art-helix-bg{
  position:absolute;inset:0;
  pointer-events:none;z-index:0;overflow:hidden;
  opacity:.22}
.art-helix-bg svg{position:absolute;top:0;left:0;width:100%;height:100%}
.art-hero > *:not(.art-helix-bg){position:relative;z-index:1}

/* ── §B-2: 螺旋プログレスレール (amber recolor) ─────────── */
.art-rail{
  position:fixed;right:4px;top:15vh;height:70vh;width:10px;
  pointer-events:none;z-index:50;overflow:visible}
.art-rail svg{overflow:visible;display:block;width:100%;height:100%}

/* レール先端発光ドット: amber */
@keyframes rail-pulse{
  0%,100%{filter:drop-shadow(0 0 3px var(--w-a)) drop-shadow(0 0 6px var(--w-a));opacity:.9}
  50%{filter:drop-shadow(0 0 8px var(--w-b)) drop-shadow(0 0 14px var(--w-b));opacity:1}
}
.art-rail-dot{animation:rail-pulse 2.4s ease-in-out infinite}

/* ── §B-3: h2 塩基対マーク (amber colors) ─────────────── */
.article h2::after{
  content:"";
  position:absolute;left:42px;top:0;
  width:14px;height:14px;
  background:
    radial-gradient(circle 2.5px at 3px 50%, var(--w-a) 100%, transparent 100%),
    radial-gradient(circle 2.5px at 11px 50%, var(--w-c) 100%, transparent 100%),
    linear-gradient(var(--w-b), var(--w-b)) 7px 0 / 1.5px 100% no-repeat;
  transform-origin:50% 50%;pointer-events:none}
.js-reveal .article h2::after{transform:scale(0);opacity:0;
  transition:transform .3s .5s cubic-bezier(.34,1.56,.64,1),opacity .2s .5s}
.js-reveal .article h2.in::after{transform:scale(1);opacity:1}

/* figure 奥行き入場 */
.js-reveal .article figure{
  opacity:0;transform:perspective(900px) translateZ(-120px);transform-origin:50% 50%;
  transition:opacity 1.0s cubic-bezier(.2,.7,.2,1),transform 1.0s cubic-bezier(.2,.7,.2,1)}
.js-reveal .article figure.in{opacity:1;transform:perspective(900px) translateZ(0)}

/* ── §B-4: アイドル微動 ─────────────────────────────────── */

/* eyecatch 流れるグラデ枠: amber */
.art-eyecatch{
  border:1px solid transparent !important;
  background:
    rgba(8,8,14,.55) padding-box,
    linear-gradient(100deg,
      var(--w-a),var(--w-b),var(--w-c),var(--w-a),var(--w-b),var(--w-c),
      var(--w-a),var(--w-b),var(--w-c),var(--w-a)) border-box;
  background-size:100% 100%, 300% 100%;
  animation:eyecatch-border 8s linear infinite}
@keyframes eyecatch-border{
  from{background-position:0 0, 0% 0}
  to{background-position:0 0, 100% 0}}

/* blockquote 左バー呼吸 */
.article blockquote::before{animation:bq-breathe 4s ease-in-out infinite}
@keyframes bq-breathe{0%,100%{opacity:.7}50%{opacity:1}}

/* ── §B-5: prefers-reduced-motion 全停止 ─────────────────── */
@media(prefers-reduced-motion:reduce){
  .art-helix-bg{display:none}
  .art-rail{display:none}
  .art-eyecatch{animation:none;background:rgba(8,8,14,.55) padding-box;border-color:rgba(236,200,90,.18) !important}
  .article blockquote::before{animation:none;opacity:1}
  .js-reveal .article h2::after{transform:scale(1) !important;opacity:1 !important;transition:none}
  .js-reveal .article figure{opacity:1 !important;transform:none !important;transition:none}
  .js-reveal .art-hero > *:not(.art-helix-bg),.js-reveal .article > *{opacity:1 !important;transform:none !important;transition:none}
  .js-reveal .article h2::before,.js-reveal .art-title::after{transform:scaleX(1) !important}
  .js-reveal .article strong{background-size:100% .16em !important}
}

/* ── 記事下部：関連記事カード＋前/次ナビ（related.js が #related-mount に生成・内部リンク） ── */
.related-mount-wrap{padding-top:6px;padding-bottom:24px}
.related-title{font-family:var(--font-jp);font-weight:700;font-size:clamp(19px,2.6vw,24px);color:var(--ink);
  margin:0 0 18px;padding-top:30px;position:relative}
.related-title::before{content:"";position:absolute;left:0;top:0;width:46px;height:3px;border-radius:3px;background:var(--w-grad)}
.related-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px;margin-bottom:42px}
.related-card{display:flex;flex-direction:column;border-radius:16px;overflow:hidden;text-decoration:none;
  background:rgba(8,8,14,.55);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);
  border:1px solid rgba(236,200,90,.18);
  transition:transform .4s cubic-bezier(.2,.7,.2,1),box-shadow .4s,border-color .4s}
.related-card:hover{transform:translateY(-4px);border-color:rgba(236,200,90,.42);
  box-shadow:0 28px 60px -34px rgba(0,0,0,.95)}
.related-thumb{aspect-ratio:16/9;background:rgba(255,255,255,.03);overflow:hidden}
.related-thumb img{width:100%;height:100%;object-fit:cover;display:block}
.related-body{padding:13px 16px 16px;display:flex;flex-direction:column;gap:8px}
.related-tag{align-self:flex-start;font-family:var(--font-tech);font-weight:600;font-size:10.5px;letter-spacing:.12em;
  text-transform:uppercase;color:var(--w-a);background:rgba(236,200,90,.10);
  border:1px solid rgba(236,200,90,.25);border-radius:999px;padding:3px 10px}
.related-name{font-family:var(--font-jp);font-weight:700;font-size:14.5px;line-height:1.55;color:var(--ink);margin:0;
  display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.related-date{font-family:var(--font-tech);font-size:12px;color:var(--ink-faint)}

/* 前/次ナビ */
.post-nav{display:flex;gap:14px;border-top:1px solid var(--line);padding-top:26px}
.pn-link{flex:1;min-width:0;display:flex;flex-direction:column;gap:6px;text-decoration:none;
  padding:16px 18px;border-radius:14px;background:rgba(8,8,14,.5);border:1px solid rgba(236,200,90,.14);
  transition:border-color .3s,background .3s}
a.pn-link:hover{border-color:rgba(236,200,90,.4);background:rgba(236,200,90,.05)}
.pn-empty{visibility:hidden;border:0;background:none;padding:0}
.pn-next{text-align:right}
.pn-label{font-family:var(--font-tech);font-size:11.5px;letter-spacing:.08em;color:var(--w-a)}
.pn-title{font-family:var(--font-jp);font-size:13px;line-height:1.5;color:var(--ink-soft);
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
@media(max-width:560px){.post-nav{flex-direction:column}.pn-empty{display:none}}

/* ── モバイル補正 ────────────────────────────────────────────── */
@media(max-width:390px){.art-rail{right:2px;width:8px}}
