/* =========================================================
   四季hack  -  sample site stylesheet
   ブランド: 四季の困りごとを、ハックする。
   ========================================================= */

:root{
  /* ベース（優しい薄緑トーン） */
  --bg:#ffffff;
  --bg-soft:#f1f7f1;
  --text:#2a322a;
  --text-soft:#5f6f60;
  --line:#e3ece3;
  --shadow:0 4px 14px rgba(40,70,45,.08);
  --shadow-lg:0 12px 30px rgba(40,70,45,.14);
  --radius:14px;
  --radius-sm:10px;
  --maxw:1120px;

  /* ブランドカラー（優しい薄緑） */
  --brand:#6aa874;
  --brand-dark:#52905f;
  --brand-soft:#e7f3e9;

  /* 季節アクセント4色（季節タブ・特集など"季節を表す箇所"だけで使用） */
  --spring:#e8849c;
  --summer:#1ba3b3;
  --autumn:#e0792b;
  --winter:#5b8fc7;

  /* サイト全体のアクセント＝薄緑で固定 */
  --accent:var(--brand);
  --accent-soft:var(--brand-soft);
}

/* ※ 全体カラーは薄緑で固定。季節の色は「季節タブ」「カテゴリラベル」「特集バナー」
      など季節を表す箇所だけにアクセントとして使う方針。 */

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  overflow-x:hidden;
  font-family:"Noto Sans JP",-apple-system,BlinkMacSystemFont,"Hiragino Kaku Gothic ProN","Yu Gothic",Meiryo,sans-serif;
  color:var(--text);
  background:var(--bg);
  line-height:1.75;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.container{max-width:var(--maxw);margin:0 auto;padding:0 20px}

/* ---------- ヘッダー ---------- */
.site-header{
  position:sticky;top:0;z-index:50;
  background:rgba(255,255,255,.92);
  backdrop-filter:saturate(180%) blur(8px);
  border-bottom:1px solid var(--line);
}
.header-inner{display:flex;align-items:center;gap:20px;height:64px}
.logo{display:flex;align-items:baseline;gap:2px;font-weight:800;font-size:1.4rem;letter-spacing:.02em}
.logo .shiki{color:var(--text)}
.logo .hack{
  color:#fff;background:var(--brand);
  padding:.05em .35em;border-radius:8px;font-family:"Courier New",monospace;
  transform:skewX(-6deg);
}
.logo .hack::before{content:"<";opacity:.55}
.logo .hack::after{content:"/>";opacity:.55}

.nav{display:flex;gap:4px;margin-left:auto}
.nav a{
  padding:.5em .9em;border-radius:999px;font-weight:700;font-size:.95rem;color:var(--text-soft);
  transition:.15s;
}
.nav a:hover{color:var(--text);background:var(--bg-soft)}
.nav a.spring:hover{color:var(--spring)}
.nav a.summer:hover{color:var(--summer)}
.nav a.autumn:hover{color:var(--autumn)}
.nav a.winter:hover{color:var(--winter)}
.nav a .ic{margin-right:.25em}

.search-btn{
  border:1px solid var(--line);background:#fff;border-radius:999px;
  width:40px;height:40px;cursor:pointer;font-size:1rem;color:var(--text-soft);
  display:grid;place-items:center;transition:.15s;
}
.search-btn:hover{border-color:var(--brand);color:var(--brand)}
.menu-toggle{display:none}

/* ---------- ヒーロー / メインビジュアル ---------- */
.hero{
  background:
    radial-gradient(1200px 400px at 10% -20%, var(--accent-soft), transparent 60%),
    radial-gradient(900px 380px at 100% 0%, var(--brand-soft), transparent 55%),
    var(--bg-soft);
  border-bottom:1px solid var(--line);
}
.hero-inner{display:grid;grid-template-columns:1.1fr .9fr;gap:40px;align-items:center;padding:56px 0}
.hero-eyebrow{
  display:inline-block;font-weight:700;font-size:.8rem;letter-spacing:.12em;
  color:var(--brand);background:#fff;border:1px solid var(--brand-soft);
  padding:.35em .8em;border-radius:999px;margin-bottom:18px;
}
.hero h1{font-size:2.6rem;line-height:1.3;margin:0 0 16px;letter-spacing:.01em}
.hero h1 .mark{
  background:linear-gradient(transparent 60%,var(--accent-soft) 60%);
  padding:0 .1em;
}
.hero p{color:var(--text-soft);font-size:1.05rem;margin:0 0 26px;max-width:30em}
.hero-cta{display:flex;gap:12px;flex-wrap:wrap}
.btn{
  display:inline-flex;align-items:center;gap:.5em;font-weight:700;
  padding:.85em 1.5em;border-radius:999px;transition:.15s;cursor:pointer;border:0;font-size:1rem;
}
.btn-primary{background:var(--accent);color:#fff;box-shadow:var(--shadow)}
.btn-primary:hover{filter:brightness(1.06);transform:translateY(-2px);box-shadow:var(--shadow-lg)}
.btn-ghost{background:#fff;color:var(--text);border:1px solid var(--line)}
.btn-ghost:hover{border-color:var(--accent);color:var(--accent)}

.hero-card{
  background:#fff;border:1px solid var(--line);border-radius:18px;padding:22px;box-shadow:var(--shadow-lg);
}
.hero-card .label{font-size:.78rem;font-weight:700;color:var(--accent);letter-spacing:.08em}
.hero-card h3{margin:.3em 0 .6em;font-size:1.2rem;line-height:1.5}
.hero-card .meta{font-size:.82rem;color:var(--text-soft)}
.hero-card img{border-radius:12px;margin-top:12px;aspect-ratio:16/9;object-fit:cover;width:100%}

/* PICKUP 注目記事スライダー（自動切替） */
.pickup-slider{position:relative}
.pickup-head{display:flex;align-items:center;justify-content:space-between}
.pickup-slide{display:none}
.pickup-slide.is-active{display:block;animation:fade .5s ease}
.pickup-slide .thumb{aspect-ratio:16/9;border-radius:12px;overflow:hidden;margin-top:12px}
.pickup-dots{display:flex;gap:7px;justify-content:center;margin-top:16px}
.pickup-dots button{width:8px;height:8px;border-radius:999px;border:0;background:#cdddd0;cursor:pointer;padding:0;transition:.2s}
.pickup-dots button.is-active{background:var(--accent);width:22px}
.pickup-auto{font-size:.66rem;color:var(--text-soft);background:var(--bg-soft);padding:.15em .6em;border-radius:999px}

/* ---------- 画像プレースホルダ（外部画像なしで見られるよう） ---------- */
.ph{width:100%;height:100%;display:grid;place-items:center;font-size:2.2rem;color:rgba(255,255,255,.9);
  background:linear-gradient(135deg,#9fb3b2,#6f8786)}
.ph.spring{background:linear-gradient(135deg,#f6a9bc,#e8849c)}
.ph.summer{background:linear-gradient(135deg,#4fc6d4,#1ba3b3)}
.ph.autumn{background:linear-gradient(135deg,#f0a05a,#e0792b)}
.ph.winter{background:linear-gradient(135deg,#8fb6dd,#5b8fc7)}
.ph.brand{background:linear-gradient(135deg,#19a99e,#0f766e)}
.ph small{position:absolute;bottom:8px;right:10px;font-size:.62rem;opacity:.7}
.thumb{position:relative}

/* ---------- セクション共通 ---------- */
.section{padding:54px 0}
.section.alt{background:var(--bg-soft)}
.section-head{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:26px;gap:16px;flex-wrap:wrap}
.section-head h2{font-size:1.6rem;margin:0;display:flex;align-items:center;gap:.5em}
.section-head h2::before{content:"";width:6px;height:1.1em;background:var(--accent);border-radius:3px}
.section-head .sub{color:var(--text-soft);font-size:.92rem;margin:.3em 0 0}
.more-link{font-weight:700;color:var(--accent);white-space:nowrap}
.more-link:hover{text-decoration:underline}

/* ---------- 特集バナー（季節4枚） ---------- */
.feature-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:16px}
.feature{
  position:relative;border-radius:var(--radius);overflow:hidden;min-height:180px;
  display:flex;flex-direction:column;justify-content:flex-end;padding:18px;color:#fff;
  box-shadow:var(--shadow);transition:.2s;
}
.feature:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.feature::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 30%,rgba(0,0,0,.55));z-index:1}
.feature>*{position:relative;z-index:2}
.feature .season-emoji{font-size:1.8rem}
.feature h3{margin:.2em 0 .1em;font-size:1.25rem}
.feature p{margin:0;font-size:.85rem;opacity:.92}
.feature.spring{background:linear-gradient(135deg,#f6a9bc,#e8849c)}
.feature.summer{background:linear-gradient(135deg,#4fc6d4,#1ba3b3)}
.feature.autumn{background:linear-gradient(135deg,#f0a05a,#e0792b)}
.feature.winter{background:linear-gradient(135deg,#8fb6dd,#5b8fc7)}

/* ---------- 季節タブ ---------- */
.tabs{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:26px}
.tab{
  border:1px solid var(--line);background:#fff;border-radius:999px;
  padding:.55em 1.2em;font-weight:700;cursor:pointer;color:var(--text-soft);transition:.15s;font-size:.95rem;
}
.tab:hover{border-color:var(--accent);color:var(--accent)}
.tab.is-active{background:var(--accent);color:#fff;border-color:var(--accent)}
/* 季節タブは季節ごとの色をまとう（全体は薄緑のまま） */
.tab[data-season="spring"]:hover{color:var(--spring);border-color:var(--spring)}
.tab[data-season="summer"]:hover{color:var(--summer);border-color:var(--summer)}
.tab[data-season="autumn"]:hover{color:var(--autumn);border-color:var(--autumn)}
.tab[data-season="winter"]:hover{color:var(--winter);border-color:var(--winter)}
.tab[data-season="spring"].is-active{background:var(--spring);border-color:var(--spring)}
.tab[data-season="summer"].is-active{background:var(--summer);border-color:var(--summer)}
.tab[data-season="autumn"].is-active{background:var(--autumn);border-color:var(--autumn)}
.tab[data-season="winter"].is-active{background:var(--winter);border-color:var(--winter)}
.tab[data-season="other"]:hover{color:var(--brand);border-color:var(--brand)}
.tab[data-season="other"].is-active{background:var(--brand);border-color:var(--brand)}

/* その他カテゴリ（季節ではないのでブランドの薄緑） */
.feature.other{background:linear-gradient(135deg,#86c191,#5a9a68)}
.cat.other{background:var(--brand)}
.dot.other{background:var(--brand)}
.nav a.other:hover{color:var(--brand)}
.ph.other{background:linear-gradient(135deg,#86c191,#5a9a68)}

/* ---------- 季節スライダー（ランダム選択＋横スライド） ---------- */
.season-slider-wrap{position:relative}
.season-slider{display:flex;gap:18px;overflow-x:auto;scroll-snap-type:x mandatory;
  padding:4px 2px 12px;scroll-behavior:smooth}
.season-slider::-webkit-scrollbar{height:8px}
.season-slider::-webkit-scrollbar-thumb{background:#d7e0e0;border-radius:99px}
.season-slider .card{flex:0 0 280px;scroll-snap-align:start}
.ss-arrow{position:absolute;top:38%;transform:translateY(-50%);width:40px;height:40px;border-radius:50%;
  border:1px solid var(--line);background:rgba(255,255,255,.95);box-shadow:var(--shadow);cursor:pointer;
  font-size:1.3rem;color:var(--text-soft);z-index:3;display:grid;place-items:center;transition:.15s}
.ss-arrow:hover{color:var(--accent);border-color:var(--accent)}
.ss-arrow.prev{left:-8px}
.ss-arrow.next{right:-8px}
@media(max-width:640px){
  .ss-arrow{display:none}                 /* スマホはスワイプで操作 */
  .season-slider .card{flex-basis:80%}
}
.tab-panel{display:none}
.tab-panel.is-active{display:block;animation:fade .3s ease}
@keyframes fade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}

/* ---------- 記事カードグリッド ---------- */
.card-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.card{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;
  display:flex;flex-direction:column;transition:.18s;
}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:transparent}
.card .thumb{position:relative;aspect-ratio:16/10;overflow:hidden}
.card .thumb img{width:100%;height:100%;object-fit:cover;transition:.4s}
.card:hover .thumb img{transform:scale(1.06)}
.card .cat{
  position:absolute;top:10px;left:10px;z-index:2;font-size:.72rem;font-weight:700;color:#fff;
  padding:.25em .7em;border-radius:999px;background:var(--accent);
}
.card .cat.spring{background:var(--spring)}
.card .cat.summer{background:var(--summer)}
.card .cat.autumn{background:var(--autumn)}
.card .cat.winter{background:var(--winter)}
.card .body{padding:16px;display:flex;flex-direction:column;gap:8px;flex:1}
.card .body h3{margin:0;font-size:1.05rem;line-height:1.5}
.card:hover .body h3{color:var(--accent)}
.card .tags{display:flex;gap:6px;flex-wrap:wrap;margin-top:auto}
.card .tags span{font-size:.72rem;color:var(--text-soft);background:var(--bg-soft);padding:.2em .6em;border-radius:6px}
.card .meta{font-size:.78rem;color:var(--text-soft)}

/* ---------- 広告枠 ---------- */
.ad{
  position:relative;background:repeating-linear-gradient(45deg,#fafbfb,#fafbfb 12px,#f2f5f5 12px,#f2f5f5 24px);
  border:1px dashed #cdd8d8;border-radius:var(--radius);
  display:grid;place-items:center;text-align:center;color:#9aa9a9;
}
.ad .ad-label{
  position:absolute;top:8px;left:8px;font-size:.62rem;font-weight:700;letter-spacing:.1em;
  color:#fff;background:#9aa9a9;padding:.15em .5em;border-radius:4px;
}
.ad .ad-note{font-size:.85rem;font-weight:700}
.ad .ad-sub{font-size:.72rem}
.ad-rect{min-height:280px}     /* レクタングル/ディスプレイ想定 */
.ad-banner{min-height:110px}   /* 横長バナー想定 */
.ad-infeed{min-height:100%}    /* インフィード（カードと同サイズ） */

/* ---------- ランキング（横スクロール） ---------- */
.rank-scroller{display:flex;gap:18px;overflow-x:auto;padding-bottom:10px;scroll-snap-type:x mandatory}
.rank-scroller::-webkit-scrollbar{height:8px}
.rank-scroller::-webkit-scrollbar-thumb{background:#d7e0e0;border-radius:99px}
.rank-card{
  position:relative;flex:0 0 260px;scroll-snap-align:start;
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;transition:.18s;
}
.rank-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.rank-num{
  position:absolute;top:-6px;left:10px;z-index:3;font-family:"Courier New",monospace;font-weight:800;
  font-size:2.4rem;color:#fff;-webkit-text-stroke:2px var(--accent);text-stroke:2px var(--accent);
  line-height:1;
}
.rank-card .thumb{aspect-ratio:16/10}
.rank-card .thumb img{width:100%;height:100%;object-fit:cover}
.rank-card .body{padding:14px}
.rank-card h3{margin:0;font-size:.98rem;line-height:1.5}
.rank-card:hover h3{color:var(--accent)}

/* ---------- トップページ：本文＋サイドバーの2カラム ---------- */
.home-body{display:grid;grid-template-columns:minmax(0,1fr) 300px;gap:40px;align-items:start}
.home-main .card-grid{grid-template-columns:repeat(2,1fr)}
.home-main .section-head{margin-bottom:22px}

/* プロフィールウィジェット */
.profile-card{text-align:center}
.profile-card .avatar{width:74px;height:74px;border-radius:50%;margin:0 auto 12px;display:grid;place-items:center;font-size:2rem;background:var(--accent-soft)}
.profile-card .pname{font-weight:700;font-size:1.02rem}
.profile-card .ptitle{font-size:.78rem;color:var(--accent);font-weight:700}
.profile-card p{font-size:.84rem;color:var(--text-soft);margin:.6em 0 0;text-align:left;line-height:1.7}

/* カテゴリ一覧ウィジェット */
.cat-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:4px}
.cat-list a{display:flex;align-items:center;justify-content:space-between;padding:.55em .7em;border-radius:8px;font-size:.9rem;transition:.15s}
.cat-list a:hover{background:var(--bg-soft);color:var(--accent);transform:translateX(3px)}
.cat-list .count{color:var(--text-soft);font-size:.78rem}
.cat-list .dot{width:.6em;height:.6em;border-radius:50%;display:inline-block;margin-right:.5em}
.cat-list .dot.spring{background:var(--spring)}
.cat-list .dot.summer{background:var(--summer)}
.cat-list .dot.autumn{background:var(--autumn)}
.cat-list .dot.winter{background:var(--winter)}

/* ---------- サイト内検索ボックス（困りごとセクション） ---------- */
.search-box{display:flex;align-items:center;gap:8px;background:#fff;border:1px solid var(--line);
  border-radius:999px;padding:5px 6px 5px 16px;box-shadow:var(--shadow);min-width:300px}
.search-box:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}
.search-box .search-ic{color:#9aa9a9;font-size:.95rem;flex:0 0 auto}
.search-box input{border:0;outline:0;flex:1;min-width:0;font:inherit;font-size:.92rem;background:transparent;color:var(--text)}
.search-box input::placeholder{color:#9aa9a9}
.search-box button{flex:0 0 auto;border:0;border-radius:999px;background:var(--accent);color:#fff;
  cursor:pointer;font-weight:700;font-size:.86rem;padding:.6em 1.2em;transition:.15s;font-family:inherit}
.search-box button:hover{filter:brightness(1.06)}
.search-empty{margin:0 0 18px;color:var(--text-soft);font-size:.9rem;background:#fff;
  border:1px dashed var(--line);border-radius:10px;padding:12px 16px}
.search-empty span{font-weight:700;color:var(--accent)}

/* ---------- 困りごと別チップ ---------- */
.trouble-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.trouble{
  display:flex;align-items:center;gap:12px;background:#fff;border:1px solid var(--line);
  border-radius:var(--radius);padding:16px;transition:.18s;
}
.trouble:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:var(--accent)}
.trouble .emoji{font-size:1.6rem;width:48px;height:48px;display:grid;place-items:center;background:var(--accent-soft);border-radius:12px}
.trouble b{display:block;font-size:1rem}
.trouble small{color:var(--text-soft)}

/* ---------- あわせて読みたい ---------- */
.also{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.also-item{
  display:flex;gap:14px;background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  overflow:hidden;transition:.18s;
}
.also-item:hover{box-shadow:var(--shadow);border-color:var(--accent)}
.also-item img{width:120px;flex:0 0 120px;object-fit:cover}
.also-item .body{padding:12px 14px;display:flex;flex-direction:column;gap:6px}
.also-item h3{margin:0;font-size:.98rem;line-height:1.45}
.also-item:hover h3{color:var(--accent)}
.also-item .meta{font-size:.76rem;color:var(--text-soft);margin-top:auto}

/* ---------- 記事ページ ---------- */
.breadcrumb{font-size:.8rem;color:var(--text-soft);padding:16px 0}
.breadcrumb a:hover{color:var(--accent)}
.article-layout{display:grid;grid-template-columns:minmax(0,1fr) 300px;gap:40px;padding:10px 0 60px}
.article{background:#fff}
.article .eyebrow{color:var(--accent);font-weight:700;font-size:.82rem;letter-spacing:.08em}
.article h1{font-size:2rem;line-height:1.4;margin:.3em 0 .4em}
.article .article-meta{display:flex;gap:14px;color:var(--text-soft);font-size:.82rem;border-bottom:1px solid var(--line);padding-bottom:16px;margin-bottom:24px;flex-wrap:wrap}
.article .lead{font-size:1.05rem;color:var(--text-soft)}
.article-hero{border-radius:var(--radius);aspect-ratio:16/9;object-fit:cover;width:100%;margin:18px 0 28px}
.article h2{font-size:1.4rem;margin:2em 0 .6em;padding-left:.5em;border-left:6px solid var(--accent)}
.article h3{font-size:1.15rem;margin:1.6em 0 .5em}
.article p{margin:0 0 1.2em}

/* 目次 */
.toc{background:var(--bg-soft);border:1px solid var(--line);border-radius:var(--radius);padding:18px 22px;margin:0 0 28px}
.toc b{display:block;margin-bottom:8px}
.toc ol{margin:0;padding-left:1.4em}
.toc a{color:var(--text-soft)}
.toc a:hover{color:var(--accent)}

/* 商品リンクボックス（Amazon/楽天） */
.product{
  border:1px solid var(--line);border-radius:var(--radius);padding:18px;margin:24px 0;
  display:grid;grid-template-columns:140px 1fr;gap:18px;background:#fff;box-shadow:var(--shadow);
}
.product img{border-radius:10px;aspect-ratio:1;object-fit:cover}
.product .p-body{display:flex;flex-direction:column;gap:6px}
.product .p-cat{font-size:.72rem;font-weight:700;color:var(--accent)}
.product h4{margin:0;font-size:1.05rem;line-height:1.5}
.product .p-price{font-weight:800;font-size:1.2rem;color:#c0392b}
.product .p-btns{display:flex;gap:8px;flex-wrap:wrap;margin-top:6px}
.btn-amazon{background:#ff9900;color:#1f2a2a}
.btn-rakuten{background:#bf0000;color:#fff}
.btn-amazon,.btn-rakuten{padding:.6em 1.2em;border-radius:8px;font-weight:700;font-size:.9rem;transition:.15s}
.btn-amazon:hover,.btn-rakuten:hover{filter:brightness(1.05);transform:translateY(-1px)}

/* 記事内広告 */
.ad-inarticle{margin:30px 0}

/* まとめボックス */
.summary-box{background:var(--accent-soft);border-radius:var(--radius);padding:20px 24px;margin:30px 0}
.summary-box b{display:flex;align-items:center;gap:.4em;margin-bottom:8px;color:var(--brand-dark)}
.summary-box ul{margin:0;padding-left:1.3em}

/* サイドバー */
.sidebar{display:flex;flex-direction:column;gap:24px;position:sticky;top:84px;align-self:start}
.widget{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:18px}
.widget h4{margin:0 0 14px;font-size:1rem;display:flex;align-items:center;gap:.4em}
.widget h4::before{content:"";width:5px;height:1em;background:var(--accent);border-radius:3px}
.widget .rank-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:12px}
.widget .rank-list li{display:flex;gap:10px;align-items:flex-start}
.widget .rank-list .n{font-family:"Courier New",monospace;font-weight:800;color:var(--accent);font-size:1.1rem;flex:0 0 1.2em}
.widget .rank-list a{font-size:.9rem;line-height:1.5}
.widget .rank-list a:hover{color:var(--accent)}

/* ---------- フッター ---------- */
.site-footer{background:#0e1c1b;color:#cfdcdb;padding:48px 0 24px;margin-top:20px}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:30px;margin-bottom:30px}
.site-footer .logo .shiki{color:#fff}
.site-footer p{color:#90a4a3;font-size:.88rem;margin:.8em 0 0;max-width:26em}
.site-footer h5{font-size:.95rem;margin:0 0 12px;color:#fff}
.site-footer ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}
.site-footer a{color:#aebdbc;font-size:.88rem}
.site-footer a:hover{color:#fff}
.footer-bottom{border-top:1px solid #21302f;padding-top:18px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;font-size:.8rem;color:#7e9291}
.affiliate-note{background:#152625;border-radius:10px;padding:12px 16px;font-size:.78rem;color:#90a4a3;margin-bottom:24px}

/* ---------- カードのバッジ＆メタ情報（記事情報を目立たせる） ---------- */
.badge{position:absolute;top:10px;right:10px;z-index:2;font-size:.64rem;font-weight:800;color:#fff;
  padding:.22em .6em;border-radius:6px;letter-spacing:.05em;box-shadow:0 2px 6px rgba(0,0,0,.15)}
.badge-new{background:#e0792b}
.badge-hot{background:#c0392b}
.card .metarow{display:flex;gap:12px;flex-wrap:wrap;font-size:.76rem;color:var(--text-soft)}
.card .metarow .views{font-weight:700;color:var(--accent)}
.rank-card .rmeta{font-size:.74rem;color:var(--text-soft);margin-top:4px}
.rank-card .rmeta .views{font-weight:700;color:var(--accent)}

/* ---------- 読了プログレスバー ---------- */
.read-progress{position:fixed;top:0;left:0;height:3px;width:0;background:var(--accent);z-index:60;transition:width .08s linear}

/* ---------- 記事内ブログカード（本文中の回遊リンク） ---------- */
.blogcard{display:block;position:relative;overflow:hidden;background:#fff;border:1px solid var(--line);
  border-radius:var(--radius);margin:28px 0;transition:.18s}
.blogcard:hover{border-color:var(--accent);box-shadow:var(--shadow-lg);transform:translateY(-2px)}
.blogcard-label{display:inline-block;font-size:.7rem;font-weight:700;color:var(--accent);
  background:var(--accent-soft);padding:.3em .9em;border-bottom-right-radius:12px}
.blogcard-inner{display:flex;gap:16px;padding:14px 16px 16px}
.blogcard-thumb{flex:0 0 128px;aspect-ratio:4/3;border-radius:10px;overflow:hidden}
.blogcard-body{display:flex;flex-direction:column;gap:6px}
.blogcard-body h4{margin:0;font-size:1.04rem;line-height:1.5}
.blogcard:hover .blogcard-body h4{color:var(--accent)}
.blogcard-body p{margin:0;font-size:.84rem;color:var(--text-soft);line-height:1.65}
.blogcard-cat{font-size:.76rem;color:var(--text-soft);margin-top:auto}

/* ---------- タグリンク（タグアーカイブへ回遊） ---------- */
.tag-links{display:flex;flex-wrap:wrap;gap:8px;margin:26px 0 10px}
.tag-links a{font-size:.82rem;background:var(--bg-soft);color:var(--text-soft);
  padding:.4em .95em;border-radius:999px;transition:.15s}
.tag-links a:hover{background:var(--accent);color:#fff;transform:translateY(-1px)}

/* ---------- 前後記事ナビ ---------- */
.prevnext{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin:36px 0 10px}
.prevnext a{display:flex;flex-direction:column;gap:4px;border:1px solid var(--line);border-radius:var(--radius);
  padding:14px 16px;background:#fff;transition:.18s}
.prevnext a:hover{border-color:var(--accent);box-shadow:var(--shadow)}
.prevnext .dir{font-size:.74rem;color:var(--text-soft);font-weight:700}
.prevnext .pn-title{font-size:.92rem;line-height:1.45}
.prevnext a:hover .pn-title{color:var(--accent)}
.prevnext .next{text-align:right}

/* ---------- 商品比較表ブロック ---------- */
.compare-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;margin:26px 0;border-radius:var(--radius)}
.compare-table{width:100%;min-width:680px;border-collapse:separate;border-spacing:0;font-size:.9rem;background:#fff}
.compare-table th,.compare-table td{padding:13px 14px;border-bottom:1px solid var(--line);text-align:center;vertical-align:middle}
.compare-table thead th{background:var(--accent);color:#fff;font-weight:700;white-space:nowrap}
.compare-table thead th:first-child{border-top-left-radius:var(--radius)}
.compare-table thead th:last-child{border-top-right-radius:var(--radius)}
.compare-table tbody th{text-align:left;font-weight:700;line-height:1.4;min-width:150px}
.compare-table tbody tr:last-child th,.compare-table tbody tr:last-child td{border-bottom:0}
.compare-table tr.pick td,.compare-table tr.pick th{background:var(--accent-soft)}
.compare-table .star{color:#f0a500;letter-spacing:1px;white-space:nowrap}
.compare-table .price{font-weight:800;color:#c0392b;white-space:nowrap}
.compare-table .c-btn{display:inline-block;background:#ff9900;color:#1f2a2a;font-weight:700;
  padding:.45em 1em;border-radius:7px;font-size:.82rem;white-space:nowrap;transition:.15s}
.compare-table .c-btn:hover{filter:brightness(1.05);transform:translateY(-1px)}
.compare-table .badge-best{display:inline-block;background:var(--accent);color:#fff;font-size:.66rem;
  font-weight:700;padding:.12em .5em;border-radius:5px;margin-left:.3em;vertical-align:middle}
.compare-hint{font-size:.76rem;color:var(--text-soft);margin:-14px 0 24px;text-align:right}
@media(max-width:640px){.compare-hint{text-align:left}}

/* ---------- 季節アーカイブ（カテゴリ）ページ ---------- */
/* アーカイブはその季節のアクセント色をまとう */
body.archive-spring{--accent:var(--spring);--accent-soft:#fdecf0}
body.archive-summer{--accent:var(--summer);--accent-soft:#e1f4f6}
body.archive-autumn{--accent:var(--autumn);--accent-soft:#fceadb}
body.archive-winter{--accent:var(--winter);--accent-soft:#e8f0f9}
body.archive-other{--accent:var(--brand);--accent-soft:var(--brand-soft)}
.archive-header{background:
    radial-gradient(700px 240px at 12% -40%, var(--accent-soft), transparent 60%),
    var(--bg-soft);
  border-bottom:1px solid var(--line);padding:36px 0}
.archive-header .a-emoji{font-size:2.4rem}
.archive-header h1{font-size:2rem;margin:.2em 0 .3em;display:flex;align-items:center;gap:.4em}
.archive-header .a-desc{color:var(--text-soft);margin:0;max-width:42em}
.archive-header .a-count{display:inline-block;margin-top:12px;font-size:.82rem;font-weight:700;
  color:var(--accent);background:#fff;border:1px solid var(--accent-soft);padding:.3em .9em;border-radius:999px}
.subcat-chips{display:flex;flex-wrap:wrap;gap:8px;margin:22px 0 4px}
.subcat-chips a{font-size:.86rem;font-weight:600;background:#fff;border:1px solid var(--line);
  color:var(--text-soft);padding:.45em 1em;border-radius:999px;transition:.15s}
.subcat-chips a:hover,.subcat-chips a.is-active{background:var(--accent);color:#fff;border-color:var(--accent)}
.pagination{display:flex;justify-content:center;align-items:center;gap:6px;margin:36px 0 10px;flex-wrap:wrap}
.pagination a,.pagination span{min-width:42px;height:42px;display:grid;place-items:center;border:1px solid var(--line);
  border-radius:10px;font-weight:700;color:var(--text-soft);background:#fff;transition:.15s;padding:0 .6em}
.pagination a:hover{border-color:var(--accent);color:var(--accent)}
.pagination .current{background:var(--accent);color:#fff;border-color:var(--accent)}
.pagination .dots{border:0;background:none}
.other-seasons{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:10px}
@media(max-width:640px){.other-seasons{grid-template-columns:1fr 1fr}}

/* ---------- FAQ（SEO/LLMOで重要：質問と回答を構造化） ---------- */
.faq{margin:30px 0}
.faq details{border:1px solid var(--line);border-radius:var(--radius);margin:10px 0;background:#fff;overflow:hidden}
.faq summary{cursor:pointer;list-style:none;padding:16px 18px;font-weight:700;display:flex;gap:.6em;align-items:flex-start}
.faq summary::-webkit-details-marker{display:none}
.faq summary::before{content:"Q";flex:0 0 auto;width:1.5em;height:1.5em;display:grid;place-items:center;
  background:var(--accent);color:#fff;border-radius:6px;font-size:.85rem}
.faq summary::after{content:"＋";margin-left:auto;color:var(--text-soft);transition:.2s}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq .faq-a{padding:0 18px 18px;color:var(--text-soft);line-height:1.8}

/* ---------- CTA：トップへ戻る回遊ボックス ---------- */
.read-more-cta{background:var(--accent-soft);border-radius:var(--radius);padding:22px 24px;margin:30px 0;text-align:center}
.read-more-cta b{display:block;margin-bottom:12px;font-size:1.05rem}

/* ---------- 固定ページ（About / 問い合わせ / プライバシー） ---------- */
.page-hero{background:
    radial-gradient(700px 220px at 14% -40%, var(--accent-soft), transparent 60%), var(--bg-soft);
  border-bottom:1px solid var(--line);padding:34px 0}
.page-hero h1{font-size:1.9rem;margin:.1em 0 .25em;display:flex;align-items:center;gap:.4em}
.page-hero p{color:var(--text-soft);margin:0}
.page-narrow{max-width:760px;margin:0 auto;padding:42px 0 60px}
.page-narrow h2{font-size:1.3rem;margin:1.9em 0 .5em;padding-left:.5em;border-left:5px solid var(--accent)}
.page-narrow h2:first-child{margin-top:0}
.page-narrow h3{font-size:1.08rem;margin:1.4em 0 .4em}
.page-narrow p{margin:0 0 1.1em}
.page-narrow ul,.page-narrow ol{margin:0 0 1.1em;padding-left:1.4em}
.page-narrow li{margin:.3em 0}
.page-narrow a{color:var(--accent);text-decoration:underline}
.page-updated{font-size:.82rem;color:var(--text-soft);margin-bottom:24px}
.profile-box{display:flex;gap:18px;align-items:center;background:var(--bg-soft);border:1px solid var(--line);
  border-radius:var(--radius);padding:18px;margin:0 0 26px}
.profile-box .avatar{width:74px;height:74px;border-radius:50%;background:var(--accent-soft);
  display:grid;place-items:center;font-size:2rem;flex:0 0 auto}
.profile-box .pname{font-weight:700;font-size:1.05rem}
.profile-box .ptitle{font-size:.8rem;color:var(--accent);font-weight:700}
.data-table{width:100%;border-collapse:collapse;margin:0 0 24px;font-size:.92rem}
.data-table th,.data-table td{border:1px solid var(--line);padding:11px 13px;text-align:left;vertical-align:top}
.data-table th{background:var(--bg-soft);white-space:nowrap;width:32%}

/* 問い合わせフォーム */
.contact-form{display:flex;flex-direction:column;gap:16px;max-width:640px}
.contact-form .field label{font-weight:700;font-size:.92rem;display:block;margin-bottom:6px}
.contact-form .req{color:#c0392b;font-size:.78rem;margin-left:.3em}
.contact-form input,.contact-form textarea{width:100%;border:1px solid var(--line);border-radius:10px;
  padding:12px 14px;font:inherit;font-size:.95rem;background:#fff}
.contact-form input:focus,.contact-form textarea:focus{outline:0;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}
.contact-form textarea{min-height:150px;resize:vertical}
.contact-form .form-note{font-size:.82rem;color:var(--text-soft);line-height:1.7}
.contact-form .agree{display:flex;gap:8px;align-items:flex-start;font-size:.9rem}
.contact-form .agree input{width:auto;margin-top:.2em}
.contact-form button{align-self:flex-start;background:var(--accent);color:#fff;border:0;font-weight:700;
  padding:.85em 2.2em;border-radius:999px;cursor:pointer;font-size:1rem;transition:.15s}
.contact-form button:hover{filter:brightness(1.07);transform:translateY(-1px)}
.form-msg{background:var(--accent-soft);border-radius:10px;padding:14px 16px;font-weight:700;color:var(--brand-dark)}
@media(max-width:640px){
  .data-table th{width:38%}
  .page-hero h1{font-size:1.55rem}
}

/* ---------- お得ページ ＆ ヘッダーのお得リンク ---------- */
.deals-link{display:inline-flex;align-items:center;gap:.3em;background:#e0533f;color:#fff;font-weight:700;
  font-size:.9rem;padding:.55em 1.05em;border-radius:999px;white-space:nowrap;transition:.15s;
  box-shadow:0 3px 10px rgba(224,83,63,.3)}
.deals-link:hover{filter:brightness(1.07);transform:translateY(-1px)}

/* お得ページはセールの赤をアクセントに */
body.page-deals{--accent:#e0533f;--accent-soft:#fdeae6}
.deals-hero{background:linear-gradient(135deg,#ff8a5c,#e0533f);color:#fff;padding:46px 0}
.deals-hero .a-emoji{font-size:2.4rem}
.deals-hero h1{font-size:2.1rem;margin:.15em 0 .3em}
.deals-hero p{opacity:.96;margin:0;max-width:42em;line-height:1.7}
.deals-hero .deals-note{display:inline-block;margin-top:14px;font-size:.78rem;background:rgba(255,255,255,.22);
  padding:.35em .9em;border-radius:999px}

.deal-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.deal-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;
  position:relative;display:flex;flex-direction:column;transition:.18s}
.deal-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.deal-badge{position:absolute;top:10px;left:10px;z-index:2;background:#e0533f;color:#fff;font-weight:800;
  font-size:.8rem;padding:.28em .7em;border-radius:8px;box-shadow:0 2px 6px rgba(0,0,0,.2)}
.deal-card .thumb{aspect-ratio:16/11}
.deal-card .body{padding:15px;display:flex;flex-direction:column;gap:8px;flex:1}
.deal-card h3{margin:0;font-size:1rem;line-height:1.5}
.deal-card .timer{font-size:.74rem;color:#e0533f;font-weight:700}
.deal-price{display:flex;align-items:baseline;gap:8px;flex-wrap:wrap}
.deal-price .old{color:var(--text-soft);text-decoration:line-through;font-size:.85rem}
.deal-price .new{color:#c0392b;font-weight:800;font-size:1.3rem}
.deal-price .off{background:#fdeae6;color:#c0392b;font-weight:700;font-size:.72rem;padding:.1em .5em;border-radius:5px}
.deal-card .c-btn{margin-top:auto;text-align:center;display:block;background:#ff9900;color:#1f2a2a;
  font-weight:700;padding:.6em;border-radius:8px;transition:.15s}
.deal-card .c-btn:hover{filter:brightness(1.05)}
@media(max-width:980px){.deal-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:640px){.deal-grid{grid-template-columns:1fr}}

/* ---------- スライド式ドロワーメニュー（スマホ） ---------- */
.drawer-overlay{position:fixed;inset:0;background:rgba(20,35,22,.45);opacity:0;visibility:hidden;
  transition:.25s;z-index:70}
.drawer-overlay.is-open{opacity:1;visibility:visible}
.drawer{position:fixed;top:0;right:0;height:100%;width:84%;max-width:320px;background:#fff;z-index:71;
  transform:translateX(100%);transition:transform .28s ease;overflow-y:auto;
  box-shadow:-8px 0 30px rgba(0,0,0,.18);display:flex;flex-direction:column}
.drawer.is-open{transform:none}
.drawer-head{display:flex;align-items:center;justify-content:space-between;padding:16px 18px;
  border-bottom:1px solid var(--line);position:sticky;top:0;background:#fff;z-index:1}
.drawer-close{width:42px;height:42px;border:1px solid var(--line);background:#fff;border-radius:10px;
  font-size:1.1rem;cursor:pointer;color:var(--text-soft)}
.drawer-nav{padding:8px 18px 36px;display:flex;flex-direction:column}
.drawer-label{font-size:.72rem;font-weight:700;color:var(--text-soft);letter-spacing:.08em;margin:20px 0 4px}
.drawer-nav>a{padding:.85em .2em;border-bottom:1px solid var(--line);font-weight:600;font-size:.98rem}
.drawer-nav>a:active{color:var(--accent)}
.drawer-chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}
.drawer-chips a{font-size:.82rem;background:var(--bg-soft);padding:.45em .95em;border-radius:999px;color:var(--text-soft)}
.drawer-chips a:active{background:var(--accent);color:#fff}
body.no-scroll{overflow:hidden}

/* ---------- フッター固定ナビ（スマホ・常時表示で回遊強化） ---------- */
.mobile-bottom-nav{display:none}

/* ---------- 上へ戻る浮動ボタン（PC/タブレット） ---------- */
.to-top-float{position:fixed;right:18px;bottom:24px;width:46px;height:46px;border-radius:50%;
  background:var(--accent);color:#fff;border:0;font-size:1.2rem;cursor:pointer;z-index:54;
  box-shadow:var(--shadow-lg);opacity:0;visibility:hidden;transform:translateY(8px);transition:.25s}
.to-top-float.show{opacity:1;visibility:visible;transform:none}

/* ---------- レスポンシブ ---------- */
@media(max-width:980px){
  .hero-inner{grid-template-columns:1fr;gap:28px}
  .hero h1{font-size:2.1rem}
  .feature-grid{grid-template-columns:repeat(2,1fr)}
  .card-grid{grid-template-columns:repeat(2,1fr)}
  .trouble-grid{grid-template-columns:repeat(2,1fr)}
  .article-layout{grid-template-columns:1fr}
  .home-body{grid-template-columns:1fr}
  .sidebar{position:static}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:640px){
  .nav{display:none}
  .menu-toggle{display:grid;place-items:center;width:40px;height:40px;border:1px solid var(--line);background:#fff;border-radius:10px;cursor:pointer;font-size:1.2rem}
  .search-btn{margin-left:auto}            /* ナビ非表示時に右寄せを維持 */
  .header-inner{gap:10px}
  .card-grid,.also,.feature-grid{grid-template-columns:1fr}
  .home-main .card-grid{grid-template-columns:1fr}
  .trouble-grid{grid-template-columns:1fr 1fr}  /* チップは2列で見やすく */
  .section{padding:40px 0}
  .hero-inner{padding:40px 0}
  .hero h1{font-size:1.7rem}
  .section-head h2{font-size:1.35rem}
  .product{grid-template-columns:1fr}
  .product img,.product .thumb{max-width:200px;margin:0 auto}
  .footer-grid{grid-template-columns:1fr}
  .blogcard-thumb{flex-basis:92px}
  .prevnext{grid-template-columns:1fr}
  .prevnext .next{text-align:left}
  .article h1{font-size:1.55rem}
  .breadcrumb{font-size:.74rem}
  .search-box{width:100%;min-width:0}

  /* フッター固定ナビを表示 */
  .mobile-bottom-nav{display:grid;grid-template-columns:repeat(5,1fr);
    position:fixed;left:0;right:0;bottom:0;z-index:56;
    background:rgba(255,255,255,.97);backdrop-filter:saturate(180%) blur(8px);
    border-top:1px solid var(--line);box-shadow:0 -4px 14px rgba(40,70,45,.08)}
  .mobile-bottom-nav a,.mobile-bottom-nav button{
    display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;
    padding:9px 0 calc(9px + env(safe-area-inset-bottom));
    font-size:.64rem;color:var(--text-soft);background:none;border:0;cursor:pointer;
    font-family:inherit;min-height:54px;text-align:center}
  .mobile-bottom-nav .ic{font-size:1.2rem;line-height:1}
  .mobile-bottom-nav a:active,.mobile-bottom-nav button:active{color:var(--accent)}
  /* 固定ナビ分の余白を確保（最後のコンテンツが隠れないように） */
  body{padding-bottom:62px}
  .to-top-float{display:none}            /* スマホは固定ナビの「上へ」を使う */
  .sidebar{position:static}              /* 念のため固定解除 */
}
@media(max-width:360px){
  .container{padding:0 14px}
  .logo{font-size:1.2rem}
  .trouble-grid{grid-template-columns:1fr}
}
