/* ============================================================
   汎用アフィリ静的サイト・キット — 共通スタイルシート
   デザインの一元管理ファイル。色・余白はここだけ直せば全ページ反映。
   ============================================================ */

/* --- デザイントークン（ここで色・幅を一括変更） --- */
:root{
  --bg:#f7f6f8;      /* 背景 */
  --tx:#1c1a1f;      /* 本文文字 */
  --ac:#4f46e5;      /* アクセント（インディゴ） */
  --ac2:#818cf8;     /* アクセント明（ロゴ・縁） */
  --rd:#e11d48;      /* CTA・強調（ローズ） */
  --gd:#f59e0b;      /* ゴールド（CTA枠） */
  --bd:#e7e5ea;      /* ボーダー */
  --dk:#15131a;      /* ダーク（ヘッダー/フッター） */
  --dk2:#1f1c26;     /* ダーク2（プロフ枠） */
  --ttl-bg:#eef0fb;  /* 見出し背景（アクセントの淡色・テーマで変更可） */
  --mx:1080px;       /* コンテンツ最大幅 */
}

*{margin:0;padding:0;box-sizing:border-box}
body{font-family:'M PLUS Rounded 1c',sans-serif;background:var(--bg);color:var(--tx);line-height:2.0;font-size:16px}
a{color:var(--ac);text-decoration:none}a:hover{text-decoration:underline}
.w{max-width:var(--mx);margin:0 auto;padding:0 20px}

/* --- 読了バー --- */
#progress{position:fixed;top:0;left:0;height:3px;background:var(--rd);width:0;z-index:9999;transition:width .1s}

/* --- ヘッダー（1段） --- */
header{background:var(--dk);position:sticky;top:0;z-index:100;border-bottom:1px solid #2c2833}
header .w{display:flex;justify-content:space-between;align-items:center;gap:8px;padding-top:14px;padding-bottom:14px}
.logo{font-size:18px;font-weight:700;color:#fff;white-space:nowrap}.logo span{color:var(--ac2)}
header nav{display:flex;gap:4px;flex-wrap:wrap;justify-content:flex-end}
header nav a{font-size:13.5px;color:#cbc9d4;padding:6px 12px;border-radius:18px;transition:all .2s}
header nav a:hover{background:var(--ac);color:#fff;text-decoration:none}
.h-right{display:flex;align-items:center;gap:14px;flex-wrap:wrap;justify-content:flex-end}

/* --- サイト内検索 --- */
.search-box{display:flex;align-items:center;gap:6px;position:relative}
.search-box input{font-size:13px;padding:6px 12px;border:1px solid #2c2833;background:#0f0d14;color:#fff;border-radius:20px;width:140px;outline:none;transition:width .3s}
.search-box input::placeholder{color:#6b6873}
.search-box input:focus{width:200px;border-color:var(--ac)}
.search-box button{background:var(--ac);color:#fff;border:none;padding:6px 14px;border-radius:20px;font-size:12px;cursor:pointer;white-space:nowrap}
.search-results{position:absolute;top:calc(100% + 6px);right:0;min-width:300px;background:#fff;border:1px solid var(--bd);border-radius:8px;max-height:340px;overflow-y:auto;box-shadow:0 8px 24px rgba(0,0,0,.2);display:none;z-index:200}
.search-results a{display:block;padding:10px 14px;font-size:13.5px;color:var(--tx);border-bottom:1px solid #f0eff3}
.search-results a:last-child{border:none}
.search-results a:hover{background:#eef2ff;text-decoration:none}
.search-results .rc{font-size:11px;color:var(--ac);display:block;margin-bottom:2px}
.search-results .nf{padding:14px;color:#8a8693;font-size:13px}
.search-results .sr-count{padding:8px 14px;font-size:11px;color:#8a8693;background:#faf9fb;border-bottom:1px solid #f0eff3;position:sticky;top:0}
.search-results .sr-more{padding:10px 14px;font-size:12px;color:#8a8693;background:#faf9fb;text-align:center}

/* --- PREV / NEXT 記事ナビ --- */
.pn{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin:36px 0 8px}
.pn a{display:block;background:#fff;border:1px solid var(--bd);border-radius:10px;padding:14px 16px;color:var(--tx);transition:box-shadow .15s,transform .15s}
.pn a:hover{box-shadow:0 6px 16px rgba(0,0,0,.08);transform:translateY(-2px);text-decoration:none}
.pn-next{text-align:right}
.pn .pn-l{display:block;font-size:12px;color:#8a8693;margin-bottom:4px}
.pn .pn-t{display:block;font-size:14px;font-weight:700;line-height:1.45;color:var(--ac)}
.pn a.empty{visibility:hidden}

/* --- トップのヒーロー --- */
.hero{background:linear-gradient(135deg,#0c0a14 0%,#1e1b3a 45%,#312e81 100%);color:#fff;padding:48px 20px 52px;text-align:center;position:relative;overflow:hidden}
.hero::before{content:'';position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle,rgba(129,140,248,.08) 0%,transparent 70%);animation:pulse 8s ease-in-out infinite}
@keyframes pulse{0%,100%{transform:scale(1)}50%{transform:scale(1.15)}}
.hero img{width:82px;height:82px;border-radius:50%;border:3px solid var(--ac2);object-fit:cover;position:relative;margin-bottom:16px}
.hero h1{font-size:25px;line-height:1.45;position:relative}
.hero p{font-size:15px;opacity:.85;margin-top:14px;position:relative;max-width:600px;margin-left:auto;margin-right:auto}

/* --- 2カラム --- */
.container{max-width:var(--mx);margin:28px auto 40px;padding:0 20px;display:grid;grid-template-columns:minmax(0,1fr) 304px;gap:36px;align-items:start}
main{min-width:0}

/* --- パンくず --- */
.bread{font-size:13px;color:#8a8693;margin:0 0 0}.bread a{color:#8a8693}.bread span{margin:0 6px}

/* --- 記事タイトルバナー --- */
.fv{text-align:center;padding:44px 20px 34px;background:linear-gradient(135deg,#0c0a14 0%,#1e1b3a 45%,#312e81 100%);color:#fff;border-radius:16px;margin:16px 0 28px;position:relative;overflow:hidden}
.fv .tag{font-size:13px;color:#a5b4fc;letter-spacing:2px;position:relative}
.fv h1{font-size:25px;line-height:1.45;margin:10px 0 0;position:relative}
.fv .sub{font-size:14px;opacity:.82;margin-top:14px;position:relative}

/* --- 記事メタ --- */
.meta{font-size:13px;color:#8a8693;margin:18px 0 24px;display:flex;align-items:center;gap:10px}
.meta img{width:34px;height:34px;border-radius:50%;border:1px solid var(--bd)}

/* --- 記事本文 --- */
.lead{font-size:16px;padding:20px 24px;background:#fff;border-left:4px solid var(--ac);border-radius:4px;margin-bottom:28px}
article h2{font-size:21px;font-weight:700;margin:44px 0 16px;padding:13px 16px 13px 18px;background:var(--ttl-bg);border:none;border-left:5px solid var(--ac);border-radius:6px;color:var(--dk);box-shadow:0 1px 4px rgba(0,0,0,.05)}
article h3{font-size:17.5px;font-weight:700;margin:30px 0 12px;padding-left:12px;border-left:4px solid var(--gd);color:var(--tx)}
article p{margin-bottom:1.5em}
.eyecatch{width:100%;aspect-ratio:16/9;object-fit:cover;border-radius:12px;margin:8px 0 24px;display:block;box-shadow:0 4px 16px rgba(0,0,0,.12)}
.inimg{width:100%;max-width:460px;aspect-ratio:4/3;object-fit:cover;border-radius:10px;margin:18px auto;display:block;border:1px solid var(--bd)}
.imgcap{font-size:13px;color:#8a8693;text-align:center;margin:-8px 0 22px}
table{width:100%;border-collapse:collapse;margin:16px 0}
th,td{border:1px solid var(--bd);padding:10px 14px;font-size:14px;text-align:left}
th{background:#efeef3;font-weight:600}
ul,ol{margin:16px 0 16px 24px}li{margin-bottom:8px}

/* --- 目次 --- */
.toc{background:#fff;border:1px solid var(--bd);border-radius:8px;padding:16px 20px;margin:0 0 32px}
.toc summary{font-weight:700;font-size:15px;cursor:pointer;color:var(--ac)}
.toc ol{margin:12px 0 0 20px}.toc li{margin-bottom:6px;font-size:14px}.toc a{color:var(--tx)}

/* --- 体験談ボックス --- */
.exp{background:var(--dk2);color:#e8e6ef;padding:22px 24px;border-radius:12px;margin:32px 0;border:1px solid #312e81}
.exp h3{color:#a5b4fc;margin:0 0 10px}
.exp .who{display:flex;align-items:center;gap:10px;font-size:13px;color:#a5b4fc;margin-bottom:12px}
.exp .who img{width:28px;height:28px;border-radius:50%}

/* --- CTAボックス --- */
.cta{background:#fff;padding:22px 24px;border-radius:14px;margin:36px 0;border:2px solid var(--gd);box-shadow:0 4px 18px rgba(245,158,11,.12)}
.cta .ttl{color:#b45309;font-size:17px;font-weight:700;margin-bottom:6px;display:flex;align-items:center;gap:6px}
.cta .bn{display:block;margin:14px auto;border-radius:8px;border:1px solid var(--bd)}
.cta-btn{display:block;text-align:center;margin-top:12px;background:var(--rd);color:#fff!important;padding:14px 28px;border-radius:8px;font-weight:700;font-size:16px}
.cta-btn:hover{opacity:.92;text-decoration:none}
.cta .note{font-size:12px;color:#8a8693;margin-top:8px;text-align:center}

/* --- ランキング/比較表 --- */
.rank{margin:32px 0}
.rank-item{background:#fff;border:1px solid var(--bd);border-radius:14px;padding:18px 20px;margin-bottom:16px;position:relative;overflow:hidden}
.rank-item.no1{border-color:var(--gd);box-shadow:0 4px 18px rgba(245,158,11,.15)}
.rank-badge{position:absolute;top:0;left:0;background:var(--gd);color:#fff;font-size:12px;font-weight:700;padding:4px 14px;border-radius:0 0 10px 0}
.rank-item.no2 .rank-badge{background:#94a3b8}.rank-item.no3 .rank-badge{background:#c08457}
.rank-head{display:flex;align-items:center;gap:14px;margin:8px 0 12px}
.rank-head img{width:80px;height:80px;object-fit:contain;border-radius:8px;flex-shrink:0}
.rank-name{font-size:18px;font-weight:700}
.rank-stars{color:var(--gd);font-size:15px;letter-spacing:1px}
.rank-stars span{color:#8a8693;font-size:13px;margin-left:6px}
.rank-feat{font-size:14px;color:#4b4853;margin-bottom:12px}
.rank-btn{display:block;text-align:center;background:var(--rd);color:#fff!important;padding:12px;border-radius:8px;font-weight:700}
.rank-btn:hover{opacity:.92;text-decoration:none}

/* --- 掲示板スクショ（スマホ枠風・イメージ注記つき） --- */
.board{max-width:300px;margin:24px auto;text-align:center}
.board .frame{border:8px solid #1f1c26;border-radius:24px;overflow:hidden;box-shadow:0 8px 24px rgba(0,0,0,.18);background:#1f1c26}
.board .frame img{width:100%;display:block}
.board figcaption{font-size:12px;color:#8a8693;margin-top:8px}
.board .cap-svc{font-weight:700;color:var(--ac)}
.board .cap-note{display:block;font-size:10px;color:#b8b5bf;margin-top:2px}

/* --- Xポスト埋め込み --- */
.tweet-embed{margin:24px auto;max-width:550px}
.tweet-embed h3{font-size:16px;margin-bottom:10px}
.tweet-embed .twitter-tweet{margin:0 auto!important}

/* --- 吹き出し会話 --- */
.balloon{display:flex;gap:12px;margin:20px 0;align-items:flex-start}
.balloon.right{flex-direction:row-reverse}
.balloon .face{width:54px;flex-shrink:0;text-align:center}
.balloon .face img{width:54px;height:54px;border-radius:50%;object-fit:cover;border:2px solid var(--bd)}
.balloon .face span{display:block;font-size:11px;color:#8a8693;margin-top:3px}
.balloon .says{position:relative;background:#fff;border:1px solid var(--bd);border-radius:12px;padding:12px 16px;font-size:14.5px;line-height:1.7;max-width:80%}
.balloon.left .says::before{content:'';position:absolute;left:-8px;top:18px;border:7px solid transparent;border-right-color:#fff}
.balloon.right .says{background:#eef2ff;border-color:#c7d2fe}
.balloon.right .says::before{content:'';position:absolute;right:-8px;top:18px;border:7px solid transparent;border-left-color:#eef2ff}

/* --- シェア --- */
.share{display:flex;gap:10px;margin:32px 0}
.share a{flex:1;text-align:center;padding:10px;border-radius:6px;color:#fff!important;font-size:14px;font-weight:600}
.share .x{background:#000}.share .line{background:#06c755}

/* --- 注記 --- */
.kome{font-size:13px;color:#8a8693;margin:32px 0;padding:16px;background:#fff;border:1px solid var(--bd);border-radius:8px}

/* --- 著者ボックス --- */
.author-box{background:#fff;border:1px solid var(--bd);border-radius:14px;padding:22px 24px;margin:44px 0 8px}
.ab-label{display:inline-block;font-size:12px;font-weight:700;color:#fff;background:var(--ac);padding:3px 14px;border-radius:20px;margin-bottom:16px}
.ab-main{display:flex;gap:16px;align-items:flex-start}
.ab-main>img{width:74px;height:74px;border-radius:50%;object-fit:cover;border:2px solid var(--ac);flex-shrink:0}
.ab-name{font-weight:700;font-size:16px;margin-bottom:6px}.ab-name span{font-size:12px;color:#8a8693;font-weight:400}
.ab-bio{font-size:14px;color:#4b4853;line-height:1.7;margin-bottom:8px}
.ab-links{font-size:13px}

/* --- 関連記事カード --- */
.rel{margin-top:44px;padding-top:24px;border-top:1px solid var(--bd)}
.rel h3{font-size:17px;margin-bottom:16px}
.rel-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.rel-card{display:block;background:#fff;border:1px solid var(--bd);border-radius:10px;overflow:hidden;color:var(--tx);transition:box-shadow .15s,transform .15s}
.rel-card:hover{box-shadow:0 6px 18px rgba(0,0,0,.1);transform:translateY(-2px);text-decoration:none}
.rel-card img{width:100%;height:128px;object-fit:cover;display:block}
.rc-body{padding:11px 13px}
.rc-cat{display:block;font-size:11px;color:var(--ac);font-weight:700;margin-bottom:4px}
.rc-ttl{display:block;font-size:14px;line-height:1.45;font-weight:700}

/* --- サイドバー --- */
.sidebar .widget{background:#fff;border:1px solid var(--bd);border-radius:12px;padding:18px 20px;margin-bottom:22px}
.sidebar h3{font-size:15px;margin-bottom:14px;padding-bottom:8px;border-bottom:2px solid var(--bd);color:var(--ac)}
.w-prof{background:var(--dk2)!important;color:#e8e6ef;text-align:center;border-color:#312e81!important}
.w-prof img{width:72px;height:72px;border-radius:50%;border:2px solid var(--ac2);object-fit:cover;margin-bottom:10px}
.w-prof h3{border:none;color:#a5b4fc;padding:0;margin-bottom:8px;font-size:16px}
.w-prof p{font-size:13px;color:#cbc9d4;line-height:1.6}.w-prof a{color:#a5b4fc;font-size:13px}
.w-pop a{display:flex;gap:10px;align-items:center;margin-bottom:13px;color:var(--tx)}.w-pop a:last-child{margin-bottom:0}
.w-pop img{width:60px;height:44px;object-fit:cover;border-radius:6px;flex-shrink:0}
.w-pop span{font-size:13px;line-height:1.45}.w-pop a:hover{text-decoration:none;color:var(--ac)}
.w-cat a{display:block;padding:8px 0;font-size:14px;border-bottom:1px solid #f0eff3;color:var(--tx)}.w-cat a:last-child{border:none}
.w-cat a:hover{color:var(--ac);text-decoration:none}
.side-cta{display:block;text-align:center;margin-top:10px;background:var(--rd);color:#fff!important;padding:11px;border-radius:8px;font-weight:700;font-size:14px}
.side-cta:hover{opacity:.92;text-decoration:none}
/* サイドバー ランキング */
.w-rank .sr-item{display:flex;align-items:center;gap:10px;padding:11px 0;border-bottom:1px solid #f0eff3}
.w-rank .sr-item:last-of-type{border-bottom:none}
.w-rank .sr-item:hover{text-decoration:none}
.w-rank .sr-badge{width:24px;height:24px;border-radius:50%;background:var(--gd);color:#fff;font-weight:700;font-size:13px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.w-rank .sr-item.no2 .sr-badge{background:#94a3b8}.w-rank .sr-item.no3 .sr-badge{background:#c08457}
.w-rank .sr-name{font-size:14px;font-weight:700;line-height:1.3;color:var(--tx)}
.w-rank .sr-stars{display:block;font-size:11px;color:var(--gd);font-weight:400}
.w-rank .sr-cta{display:block;text-align:center;margin-top:12px;background:var(--rd);color:#fff!important;padding:10px;border-radius:8px;font-weight:700;font-size:13px}
.w-rank .sr-cta:hover{opacity:.92;text-decoration:none}
/* サイドバー 教材LP */
.w-lp{background:linear-gradient(150deg,#1f1c26,#312e81)!important;border-color:#4f46e5!important;text-align:center}
.w-lp img{width:100%;aspect-ratio:16/9;object-fit:cover;border-radius:8px;margin-bottom:12px}
.w-lp .lp-tag{display:inline-block;font-size:11px;font-weight:700;background:var(--gd);color:#15131a;padding:3px 12px;border-radius:10px;margin-bottom:10px}
.w-lp h3{border:none;color:#fff;padding:0;font-size:16px;margin-bottom:6px;line-height:1.45}
.w-lp p{font-size:13px;color:#cbc9d4;line-height:1.6;margin-bottom:12px}
.w-lp .lp-cta{display:block;background:var(--rd);color:#fff!important;padding:11px;border-radius:8px;font-weight:700;font-size:14px}
.w-lp .lp-cta:hover{opacity:.92;text-decoration:none}
.w-lp .lp-limited{display:block;font-size:11px;color:#fda4af;margin-top:8px;font-weight:700}

/* --- トップの記事グリッド --- */
.sec{margin-bottom:40px}
.sec h2{font-size:20px;margin-bottom:18px;padding-left:12px;border-left:4px solid var(--ac)}
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:18px}
.card{background:#fff;border:1px solid var(--bd);border-radius:12px;overflow:hidden;transition:transform .15s,box-shadow .15s}
.card:hover{transform:translateY(-3px);box-shadow:0 8px 24px rgba(0,0,0,.1)}
.card a{color:inherit;text-decoration:none;display:block}
.card img{width:100%;height:150px;object-fit:cover;display:block}
.card .body{padding:13px 15px}
.card .cat{font-size:12px;color:var(--ac);font-weight:700}
.card h3{font-size:15.5px;line-height:1.45;margin:6px 0 8px}
.card .ex{font-size:13px;color:#6b6873;line-height:1.6}
.cats{display:flex;flex-wrap:wrap;gap:10px}
.cats a{background:#fff;border:1px solid var(--bd);border-radius:20px;padding:8px 18px;font-size:14px;color:var(--tx)}
.cats a:hover{background:var(--ac);color:#fff;text-decoration:none}

/* --- フッター --- */
footer{background:var(--dk);color:#8a8693;padding:32px 0;margin-top:40px;text-align:center;font-size:13px}
footer nav{margin-top:12px}footer nav a{color:#8a8693;margin:0 10px}

/* --- スティッキーCTA --- */
.sticky-cta{position:fixed;bottom:0;left:0;right:0;background:rgba(12,10,20,.96);color:#fff;padding:10px 16px;display:flex;align-items:center;justify-content:center;gap:14px;z-index:99;transform:translateY(100%);transition:transform .3s;backdrop-filter:blur(8px)}
.sticky-cta.show{transform:translateY(0)}.sticky-cta p{font-size:13px;margin:0}.sticky-cta strong{color:var(--gd)}
.sticky-cta a{background:var(--rd);color:#fff!important;padding:8px 18px;border-radius:6px;font-size:13px;font-weight:700;white-space:nowrap}
.sticky-cta .close{background:none;border:none;color:#888;font-size:18px;cursor:pointer}

/* --- ページネーション --- */
.pg-nav{display:flex;gap:6px;justify-content:center;padding:24px 0 8px;flex-wrap:wrap;align-items:center}
.pg-nav .pg{display:inline-flex;align-items:center;justify-content:center;min-width:36px;height:36px;padding:0 8px;border:1px solid var(--bd);border-radius:6px;cursor:pointer;text-decoration:none;color:var(--tx);font-size:14px;background:#fff;transition:all .15s}
.pg-nav .pg:hover{background:var(--ac);color:#fff;border-color:var(--ac)}
.pg-nav .pg.active{background:var(--ac);color:#fff;border-color:var(--ac);font-weight:700}
.pg-nav .pg.dots{border:none;background:none;cursor:default;color:var(--tx2);min-width:20px}
/* --- スクロールトップ --- */
#to-top{position:fixed;right:20px;bottom:80px;width:44px;height:44px;background:var(--ac);color:#fff;border:none;border-radius:50%;font-size:16px;cursor:pointer;opacity:0;visibility:hidden;transition:opacity .2s,visibility .2s;z-index:200;box-shadow:0 2px 10px rgba(0,0,0,.25);line-height:1}
#to-top.show{opacity:1;visibility:visible}
#to-top:hover{background:var(--ac2)}

/* --- レスポンシブ --- */
@media(max-width:900px){.container{grid-template-columns:1fr;gap:0}.sidebar{margin-top:8px}}
@media(max-width:680px){
  .hero h1{font-size:21px}.fv h1{font-size:21px}article h1{font-size:20px}
  header .w{flex-direction:column;align-items:flex-start;gap:10px}header nav{justify-content:flex-start}
  .share{flex-direction:column}.rel-grid{grid-template-columns:1fr}.ab-main{flex-direction:column}
  .balloon .says{max-width:100%}
  .pn{grid-template-columns:1fr}
  .h-right{width:100%;justify-content:space-between}
  .search-box input{width:100%}.search-box{flex:1}
  .search-results{min-width:240px;left:0;right:auto}
}

/* ===== STORK風 共通コンポーネント（汎用） ===== */
/* ボックス装飾（ポイント/注意/メモ/OK/出典・色違い＋ラベルタブ） */
.box{position:relative;padding:16px 18px;margin:26px 0;border:2px solid var(--ac);border-radius:8px;background:var(--ttl-bg)}
.box-ttl{position:absolute;top:-12px;left:14px;padding:2px 12px;background:var(--ac);color:#fff;font-size:12.5px;font-weight:700;border-radius:5px}
.box.has-ttl{padding-top:22px}
.box>:last-child{margin-bottom:0}.box>:first-child:not(.box-ttl){margin-top:0}
.box-point{border-color:var(--ac);background:var(--ttl-bg)}.box-point .box-ttl{background:var(--ac)}
.box-note{border-color:#ef6a6a;background:#fdf2f2}.box-note .box-ttl{background:#ef6a6a}
.box-memo{border-color:#e0a82e;background:#fdf8ec}.box-memo .box-ttl{background:#e0a82e}
.box-ok{border-color:#1a9f6e;background:#eefaf5}.box-ok .box-ttl{background:#1a9f6e}
.box-src{border-color:#9aa0ac;background:#f6f7f9;font-size:13px;color:#566}.box-src .box-ttl{background:#69707c}

/* アコーディオン（<details>・JSゼロ） */
details.acc{border:1px solid var(--bd);border-radius:8px;margin:16px 0;background:#fff;overflow:hidden}
details.acc>summary{cursor:pointer;padding:13px 16px;font-weight:700;font-size:14.5px;list-style:none;position:relative}
details.acc>summary::-webkit-details-marker{display:none}
details.acc>summary::after{content:"＋";position:absolute;right:16px;color:var(--ac);font-weight:700}
details.acc[open]>summary::after{content:"−"}
details.acc>summary:hover{background:var(--ttl-bg)}
details.acc>.acc-body{padding:0 16px 14px}

/* スクロール出現アニメ（.fade-in を付けた要素が下から出現） */
.fade-in{opacity:0;transform:translateY(14px);transition:opacity .5s ease,transform .5s ease}
.fade-in.in{opacity:1;transform:none}

/* トップへ戻る */
.totop{position:fixed;right:16px;bottom:80px;width:44px;height:44px;border:none;border-radius:50%;background:var(--dk);color:#fff;font-size:20px;cursor:pointer;opacity:0;pointer-events:none;transition:opacity .25s;z-index:90;box-shadow:0 4px 14px rgba(0,0,0,.25);display:flex;align-items:center;justify-content:center}
.totop.show{opacity:.92;pointer-events:auto}.totop:hover{opacity:1}

/* SP固定フッターメニュー（モバイル回遊・config.SP_NAV で表示） */
.spnav{display:none}
@media(max-width:768px){
  .spnav{display:flex;position:fixed;left:0;right:0;bottom:0;z-index:95;background:#fff;border-top:1px solid var(--bd);box-shadow:0 -2px 12px rgba(0,0,0,.08);padding-bottom:env(safe-area-inset-bottom)}
  .spnav a{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px;padding:7px 2px 8px;color:var(--tx);font-size:10.5px;text-decoration:none}
  .spnav a i{font-size:21px;color:var(--dk)}
  .spnav a:active{background:var(--ttl-bg)}
  body{padding-bottom:58px}
  .totop{bottom:70px}
  .sticky-cta{bottom:58px}
}

.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
