/*
Theme Name: 四季hack Child v2 (SWELL Child)
Theme URI: https://example.com/
Description: SWELL用の子テーマ「四季hack」。四季のアクセントカラー、カード装飾、広告枠ラベル、季節自動判定（functions.php）を追加します。親テーマSWELLが必要です。
Author: 四季hack
Author URI: https://example.com/
Template: swell
Version: 1.0.0
Text Domain: shikihack-child
*/

/* =========================================================
   四季hack ブランド追加CSS
   ※ SWELL本体のレイアウトはそのまま活かし、色と装飾だけ上乗せします。
   ※ 色を微調整したい場合は下の変数値を変えるだけでOK。
   ========================================================= */

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

  /* 季節アクセント4色 */
  --shk-spring:#e8849c;
  --shk-summer:#1ba3b3;
  --shk-autumn:#e0792b;
  --shk-winter:#5b8fc7;

  /* 現在のアクセント（body の season-* クラスで切り替わる） */
  --shk-accent:var(--shk-brand);
  --shk-accent-soft:var(--shk-brand-soft);

  /* コンポーネント用トークン */
  --shk-line:#e3ece3;
  --shk-text-soft:#5f6f60;
  --shk-bg-soft:#f1f7f1;
  --shk-radius:14px;
  --shk-shadow:0 4px 14px rgba(40,70,45,.08);
  --shk-shadow-lg:0 12px 30px rgba(40,70,45,.14);
}

/* 全体カラーは「優しい薄緑」で固定。季節色は季節を表す箇所だけにアクセントとして使う。
   ↓ 季節で全体色も変えたい場合は、この4行のコメントを外せば自動切替に戻せます。 */
/*
body.season-spring{--shk-accent:var(--shk-spring);--shk-accent-soft:#fdecf0}
body.season-summer{--shk-accent:var(--shk-summer);--shk-accent-soft:#e1f4f6}
body.season-autumn{--shk-accent:var(--shk-autumn);--shk-accent-soft:#fceadb}
body.season-winter{--shk-accent:var(--shk-winter);--shk-accent-soft:#e8f0f9}
*/

/* ---- 季節カテゴリのアーカイブは、その季節の色をまとう ----
   WordPressがカテゴリ一覧ページに自動で付ける body クラス category-{スラッグ} を利用。
   親カテゴリのスラッグを spring/summer/autumn/winter/other にしておけば自動適用されます。
   子カテゴリ（結露・加湿 等）も親と同じ色にするため category-子スラッグ を足したい場合は
   ここに追記してください（任意）。 */
body.category-spring{--shk-accent:var(--shk-spring);--shk-accent-soft:#fdecf0}
body.category-summer{--shk-accent:var(--shk-summer);--shk-accent-soft:#e1f4f6}
body.category-autumn{--shk-accent:var(--shk-autumn);--shk-accent-soft:#fceadb}
body.category-winter{--shk-accent:var(--shk-winter);--shk-accent-soft:#e8f0f9}
body.category-other{--shk-accent:var(--shk-brand);--shk-accent-soft:var(--shk-brand-soft)}

/* ---- ロゴ風アクセント（任意：サイトロゴをテキストにしている場合） ---- */
.shk-logo .hack{
  color:#fff;background:var(--shk-brand);
  padding:.05em .35em;border-radius:8px;font-family:"Courier New",monospace;
}

/* ---- 見出し（投稿本文の H2/H3 に季節アクセント） ---- */
.post_content h2{
  background:var(--shk-brand)!important;
  color:#fff!important;
  border-left:6px solid #3f7a4f!important;
  border-radius:6px;
  padding:.55em .8em!important;
}
.post_content h2 *{color:#fff!important}
}
.post_content h3{
  border-bottom:2px solid var(--shk-accent-soft);
}

/* ---- リンク・ボタンのホバーを季節色に寄せる ---- */
.post_content a:hover{color:var(--shk-accent)}

/* ---- 記事カード：ホバーで少し浮かせる（回遊促進） ---- */
.p-postList__link:hover,
.c-postThumb:hover{
  transform:translateY(-3px);
  transition:transform .18s ease;
}

/* ---- カテゴリラベルを季節色に（必要に応じてカテゴリ別クラスで上書き） ---- */
.cat-label, .c-postThumb__cat{
  background:var(--shk-accent) !important;
}

/* ---- 広告枠ラベル（「広告/PR」表記用の汎用クラス） ----
   使い方: <p class="shk-ad-label">広告</p> を広告ブロックの直前に置く。
   景表法・ステマ規制対応として、広告には必ず表記を入れること。 */
.shk-ad-label{
  display:inline-block;
  font-size:.68rem;font-weight:700;letter-spacing:.08em;
  color:#fff;background:#9aa9a9;
  padding:.15em .6em;border-radius:4px;margin:0 0 4px;
}

/* ---- 商品リンクボックスの簡易装飾（SWELLの「カラム」ブロック等に追加クラスで適用可） ---- */
.shk-product{
  border:2px solid #b7c9bb;border-radius:14px;padding:18px;margin:24px 0;
  box-shadow:0 4px 14px rgba(15,40,40,.08);
}
.shk-product .shk-price{font-weight:800;font-size:1.2rem;color:#c0392b}

/* ---- 「今の季節」を示す小バッジ（任意でメニュー等に） ---- */
.shk-season-badge{
  display:inline-flex;align-items:center;gap:.3em;
  background:var(--shk-accent-soft);color:var(--shk-accent);
  font-weight:700;font-size:.8rem;padding:.2em .7em;border-radius:999px;
}

/* =========================================================
   四季hack コンポーネントCSS
   - [shiki_pickup] / [shiki_season_slider] の表示に必要
   - 比較表・セールカード・バッジ等はカスタムHTMLブロックで流用可
   ========================================================= */

/* 画像プレースホルダ（アイキャッチ未設定時にショートコードが出力） */
.ph{width:100%;height:100%;min-height:120px;display:grid;place-items:center;font-size:2rem;
  color:rgba(255,255,255,.92);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.other,.ph.brand{background:linear-gradient(135deg,#86c191,#5a9a68)}

/* カテゴリラベル（季節色） */
.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(--shk-accent)}
.cat.spring{background:var(--shk-spring)}
.cat.summer{background:var(--shk-summer)}
.cat.autumn{background:var(--shk-autumn)}
.cat.winter{background:var(--shk-winter)}
.cat.other{background:var(--shk-brand)}

/* メタ情報・閲覧数 */
.metarow{display:flex;gap:12px;flex-wrap:wrap;font-size:.76rem;color:var(--shk-text-soft)}
.metarow .views,.views{font-weight:700;color:var(--shk-accent)}

/* バッジ */
.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}

/* 季節スライダー（[shiki_season_slider] 出力） */
.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(--shk-line);background:rgba(255,255,255,.95);box-shadow:var(--shk-shadow);cursor:pointer;
  font-size:1.3rem;color:var(--shk-text-soft);z-index:3;display:grid;place-items:center;transition:.15s}
.ss-arrow:hover{color:var(--shk-accent);border-color:var(--shk-accent)}
.ss-arrow.prev{left:-8px}.ss-arrow.next{right:-8px}

/* 記事カード（スライダー内で使用。汎用 .card のSWELL競合を避け文脈限定） */
.season-slider .card,.shk-cards .card{background:#fff;border:1px solid var(--shk-line);
  border-radius:var(--shk-radius);overflow:hidden;display:flex;flex-direction:column;transition:.18s;text-decoration:none;color:inherit}
.season-slider .card:hover,.shk-cards .card:hover{transform:translateY(-4px);box-shadow:var(--shk-shadow-lg)}
.season-slider .card .thumb,.shk-cards .card .thumb{position:relative;aspect-ratio:16/10;overflow:hidden}
.season-slider .card .thumb img,.shk-cards .card .thumb img{width:100%;height:100%;object-fit:cover}
.season-slider .card .body,.shk-cards .card .body{padding:14px;display:flex;flex-direction:column;gap:8px}
.season-slider .card h3,.shk-cards .card h3{margin:0;font-size:1rem;line-height:1.5}
.season-slider .card:hover h3,.shk-cards .card:hover h3{color:var(--shk-accent)}

/* PICKUP注目記事スライダー（[shiki_pickup] 出力） */
.pickup-slider{background:#fff;border:1px solid var(--shk-line);border-radius:18px;padding:22px;
  box-shadow:var(--shk-shadow-lg);position:relative}
.pickup-head{display:flex;align-items:center;justify-content:space-between}
.pickup-slider .label{font-size:.78rem;font-weight:700;color:var(--shk-accent);letter-spacing:.08em}
.pickup-auto{font-size:.66rem;color:var(--shk-text-soft);background:var(--shk-bg-soft);padding:.15em .6em;border-radius:999px}
.pickup-slide{display:none;text-decoration:none;color:inherit}
.pickup-slide.is-active{display:block;animation:shkfade .5s ease}
.pickup-slide h3{margin:.3em 0 .5em;font-size:1.2rem;line-height:1.5}
.pickup-slide .meta{font-size:.82rem;color:var(--shk-text-soft);margin:0}
.pickup-slide .thumb{aspect-ratio:16/9;border-radius:12px;overflow:hidden;margin-top:12px}
.pickup-slide .thumb img{width:100%;height:100%;object-fit:cover}
.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(--shk-accent);width:22px}
@keyframes shkfade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}

/* 記事内ブログカード（カスタムHTMLで回遊リンクに） */
.blogcard{display:block;position:relative;overflow:hidden;background:#fff;border:1px solid var(--shk-line);
  border-radius:var(--shk-radius);margin:28px 0;transition:.18s;text-decoration:none;color:inherit}
.blogcard:hover{border-color:var(--shk-accent);box-shadow:var(--shk-shadow-lg);transform:translateY(-2px)}
.blogcard-label{display:inline-block;font-size:.7rem;font-weight:700;color:var(--shk-accent);
  background:var(--shk-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 h4{margin:0 0 6px;font-size:1.04rem;line-height:1.5}
.blogcard-body p{margin:0;font-size:.84rem;color:var(--shk-text-soft);line-height:1.65}

/* 商品比較表（テーブルブロックに class="compare-table" を付与し div.compare-wrap で囲む） */
.compare-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;margin:26px 0;border-radius:var(--shk-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(--shk-line);text-align:center;vertical-align:middle}
.compare-table thead th{background:var(--shk-accent);color:#fff;font-weight:700;white-space:nowrap}
.compare-table tbody th{text-align:left;font-weight:700;min-width:150px}
.compare-table tr.pick td,.compare-table tr.pick th{background:var(--shk-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;text-decoration:none;white-space:nowrap}
.compare-table .badge-best{display:inline-block;background:var(--shk-accent);color:#fff;font-size:.66rem;font-weight:700;padding:.12em .5em;border-radius:5px;margin-left:.3em;vertical-align:middle}

/* セールカード（お得ページ用。grid化したい場合は div.deal-grid で囲む） */
.deal-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.deal-card{background:#fff;border:1px solid var(--shk-line);border-radius:var(--shk-radius);overflow:hidden;
  position:relative;display:flex;flex-direction:column;transition:.18s}
.deal-card:hover{transform:translateY(-4px);box-shadow:var(--shk-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 .thumb img{width:100%;height:100%;object-fit:cover}
.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(--shk-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;text-decoration:none}

@media(max-width:980px){.deal-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:640px){
  .deal-grid{grid-template-columns:1fr}
  .season-slider .card{flex-basis:80%}
  .ss-arrow{display:none}
  .blogcard-thumb{flex-basis:92px}
}

/* =========================================================
   商品リンクボックス（Amazon/楽天ボタン・ランキング記事用）
   ========================================================= */
.product{
  border:2px solid #b7c9bb;border-radius:var(--shk-radius);padding:18px;margin:24px 0;
  display:grid;grid-template-columns:140px 1fr;gap:18px;background:#fff;box-shadow:var(--shk-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(--shk-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{display:inline-block;padding:.6em 1.2em;border-radius:8px;font-weight:700;font-size:.9rem;text-decoration:none;transition:.15s}
.btn-amazon:hover,.btn-rakuten:hover{filter:brightness(1.05);transform:translateY(-1px)}

/* ランキング記事用ブロック */
.rank-item{margin:32px 0;border-radius:var(--shk-radius);overflow:hidden;border:2px solid var(--shk-line);box-shadow:var(--shk-shadow)}
.rank-item.rank-1{border-color:#d4a017}
.rank-item.rank-2{border-color:#9e9e9e}
.rank-item.rank-3{border-color:#b5651d}
.rank-badge{display:flex;align-items:center;gap:.5em;padding:10px 18px;font-weight:800;font-size:1rem;background:var(--shk-bg-soft);border-bottom:2px solid var(--shk-line)}
.rank-item.rank-1 .rank-badge{background:linear-gradient(90deg,#fffbe6,#fff8d0);border-color:#d4a017;color:#7a5200}
.rank-item.rank-2 .rank-badge{background:linear-gradient(90deg,#f5f5f5,#ebebeb);border-color:#9e9e9e;color:#444}
.rank-item.rank-3 .rank-badge{background:linear-gradient(90deg,#fdf0e8,#f9e4d0);border-color:#b5651d;color:#6b3300}
.rank-badge .rnum{font-size:1.8rem;line-height:1;font-family:"Courier New",monospace;min-width:2em;text-align:center}
.rank-badge .rtitle{font-size:.95rem;line-height:1.4}
.rank-item .product{border:none;border-radius:0;margin:0;box-shadow:none;background:#fff;padding:20px}
.rank-comment{background:var(--shk-bg-soft);border-left:4px solid var(--shk-accent);padding:10px 16px;margin:0 20px 20px;border-radius:0 8px 8px 0;font-size:.9rem;line-height:1.7}
.rank-item.rank-4 .rank-badge,.rank-item.rank-5 .rank-badge,.rank-item.rank-6 .rank-badge,
.rank-item.rank-7 .rank-badge,.rank-item.rank-8 .rank-badge,.rank-item.rank-9 .rank-badge,
.rank-item.rank-10 .rank-badge{background:var(--shk-bg-soft);border-color:var(--shk-line);color:var(--shk-text-soft)}

@media(max-width:640px){
  .product{grid-template-columns:1fr}
  .product img{max-width:200px;margin:0 auto}
}

/* =========================================================
   記事本文の自動装飾（the_content フィルターと対）
   ※ functions.php の shk_auto_decorate() が付与するクラス用
   ========================================================= */

/* ※ SWELLの既定装飾（h2 の擬似要素・ul li マーカー等）に確実に勝つため、
   視認に関わるプロパティは !important で固定する。 */

/* 1. リード文ボックス */
.post_content .shk-lead{
  background:var(--shk-bg-soft)!important;border:1px solid var(--shk-line);
  border-left:5px solid var(--shk-accent);border-radius:0 12px 12px 0;
  padding:16px 20px!important;font-size:1.02rem;
}

/* 3. チェックリスト */
.post_content ul.shk-check{list-style:none!important;padding:0!important;margin:1.2em 0!important;display:grid;gap:10px}
.post_content ul.shk-check li{
  background:#fff;border:1px solid var(--shk-line);border-radius:10px;
  padding:11px 14px 11px 40px!important;position:relative;margin:0!important;list-style:none!important;
}
/* SWELL が li に付ける既定マーカー/疑似要素を無効化 */
.post_content ul.shk-check li::marker{content:""!important}
.post_content ul.shk-check li::before{
  content:"✓"!important;position:absolute;left:12px;top:11px;color:#fff;background:var(--shk-accent);
  width:20px;height:20px;border-radius:50%;display:grid;place-items:center;font-size:.72rem;font-weight:800;
  border:none!important;margin:0!important;
}

/* 6. FAQアコーディオン */
.post_content .shk-faq{margin:1.4em 0}
.post_content .shk-faq details{background:#fff;border:1px solid var(--shk-line);border-radius:12px;margin:10px 0;overflow:hidden}
.post_content .shk-faq summary{cursor:pointer;list-style:none!important;padding:14px 18px 14px 44px!important;font-weight:700;position:relative}
.post_content .shk-faq summary::-webkit-details-marker{display:none}
.post_content .shk-faq summary::marker{content:""!important}
.post_content .shk-faq summary::before{content:"Q"!important;position:absolute;left:14px;top:13px;background:var(--shk-accent);color:#fff;
  width:22px;height:22px;border-radius:6px;display:grid;place-items:center;font-size:.8rem;font-weight:800}
.post_content .shk-faq summary::after{content:"＋"!important;position:absolute;right:16px;top:14px;color:var(--shk-accent);font-weight:800}
.post_content .shk-faq details[open] summary::after{content:"−"!important}
.post_content .shk-faq .a{padding:0 18px 16px 44px;color:#3a463a;position:relative}
.post_content .shk-faq .a::before{content:"A";position:absolute;left:14px;top:0;background:#cfe0d3;color:#33503a;
  width:22px;height:22px;border-radius:6px;display:grid;place-items:center;font-size:.8rem;font-weight:800}

/* 8. 重要語マーカー（黄色） */
.post_content p strong.shk-mark{background:linear-gradient(transparent 60%,#fff2a8 60%)!important;padding:0 .05em}

/* 9. まとめボックス */
.post_content h2.shk-summary{
  background:var(--shk-accent)!important;color:#fff!important;border:none!important;border-radius:12px 12px 0 0!important;
  padding:.6em .8em!important;margin-bottom:0!important;
}
/* SWELL の h2 装飾（左バー・番号・下線などの擬似要素）を消す */
.post_content h2.shk-summary::before,
.post_content h2.shk-summary::after{display:none!important;content:none!important}
.post_content h2.shk-summary + *{
  border:1px solid var(--shk-line);border-top:none;border-radius:0 0 12px 12px;
  padding:14px 18px;margin-top:0;
}

/* ---- スマホ最適化（自動装飾を崩さない） ---- */
@media(max-width:560px){
  .post_content .shk-lead{padding:13px 15px;font-size:.97rem}
  .post_content ul.shk-check li{padding:10px 12px 10px 36px}
  .post_content ul.shk-check li::before{left:10px;top:10px}
  .shk-faq summary{padding:12px 38px 12px 40px;font-size:.95rem}
  .shk-faq .a{padding:0 14px 14px 40px}
  /* 商品ボックス：縦積み・画像中央・ボタン全幅2分割 */
  .product,.shk-product{grid-template-columns:1fr;padding:14px;gap:10px}
  .product .thumb,.shk-product .thumb{text-align:center}
  .product img,.shk-product .thumb img{max-width:170px;margin:0 auto}
  .product .p-btns a,.shk-product .p-btns a{flex:1 1 0;text-align:center;padding:.7em .4em}
  /* 比較表：横スクロールのヒント表示 */
  .compare-wrap{position:relative}
  .compare-wrap::after{content:"← 横にスクロール →";display:block;text-align:center;
    font-size:.72rem;color:var(--shk-text-soft);padding:6px 0 0}
}

/* =========================================================
   トップページ（front-page.php）レイアウト
   ========================================================= */
#shk-front{font-family:inherit}
.shk-container{max-width:1120px;margin:0 auto;padding:0 20px}
.shk-section{padding:50px 0}
.shk-section.shk-alt{background:var(--shk-bg-soft)}

/* セクション見出し */
#shk-front .section-head{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-bottom:24px}
#shk-front .section-head h2{font-size:1.6rem;margin:0;display:flex;align-items:center;gap:.5em}
#shk-front .section-head h2::before{content:"";width:6px;height:1.1em;background:var(--shk-accent);border-radius:3px}
#shk-front .section-head .sub{color:var(--shk-text-soft);font-size:.92rem;margin:.3em 0 0}

/* ヒーロー */
.shk-hero{background:
    radial-gradient(1100px 380px at 8% -25%, var(--shk-accent-soft), transparent 60%),
    var(--shk-bg-soft);
  padding:56px 0;border-bottom:1px solid var(--shk-line)}
.shk-eyebrow{display:inline-block;font-weight:700;font-size:.78rem;letter-spacing:.12em;color:var(--shk-brand);
  background:#fff;border:1px solid var(--shk-accent-soft);padding:.35em .8em;border-radius:999px;margin-bottom:16px}
.shk-hero h1{font-size:2.4rem;line-height:1.35;margin:0 0 14px}
.shk-hero h1 .mark{background:linear-gradient(transparent 60%,var(--shk-accent-soft) 60%);padding:0 .1em}
.shk-hero p{color:var(--shk-text-soft);font-size:1.02rem;margin:0 0 22px;max-width:34em}
.shk-hero-cta{display:flex;gap:12px;flex-wrap:wrap}
.shk-btn{display:inline-flex;align-items:center;gap:.4em;font-weight:700;padding:.8em 1.5em;border-radius:999px;text-decoration:none;transition:.15s}
.shk-btn-primary{background:var(--shk-accent);color:#fff;box-shadow:var(--shk-shadow)}
.shk-btn-primary:hover{filter:brightness(1.06);transform:translateY(-2px)}
.shk-btn-ghost{background:#fff;color:inherit;border:1px solid var(--shk-line)}
.shk-btn-ghost:hover{border-color:var(--shk-accent);color:var(--shk-accent)}

/* 特集バナー */
.feature-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:16px}
.feature{position:relative;border-radius:var(--shk-radius);overflow:hidden;min-height:170px;display:flex;
  flex-direction:column;justify-content:flex-end;padding:18px;color:#fff;box-shadow:var(--shk-shadow);
  transition:.2s;text-decoration:none}
.feature:hover{transform:translateY(-4px);box-shadow:var(--shk-shadow-lg)}
.feature::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 30%,rgba(0,0,0,.5));z-index:1}
.feature>*{position:relative;z-index:2}
.feature .season-emoji{font-size:1.7rem}
.feature h3{margin:.2em 0 .1em;font-size:1.2rem}
.feature p{margin:0;font-size:.84rem;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)}
.feature.other{background:linear-gradient(135deg,#86c191,#5a9a68)}

/* タブ */
.tabs{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:24px}
.tab{border:1px solid var(--shk-line);background:#fff;border-radius:999px;padding:.55em 1.2em;font-weight:700;
  cursor:pointer;color:var(--shk-text-soft);transition:.15s;font-size:.95rem}
.tab:hover{border-color:var(--shk-accent);color:var(--shk-accent)}
.tab.is-active{background:var(--shk-accent);color:#fff;border-color:var(--shk-accent)}
.tab[data-season="spring"].is-active{background:var(--shk-spring);border-color:var(--shk-spring)}
.tab[data-season="summer"].is-active{background:var(--shk-summer);border-color:var(--shk-summer)}
.tab[data-season="autumn"].is-active{background:var(--shk-autumn);border-color:var(--shk-autumn)}
.tab[data-season="winter"].is-active{background:var(--shk-winter);border-color:var(--shk-winter)}
.tab[data-season="other"].is-active{background:var(--shk-brand);border-color:var(--shk-brand)}
.tab-panel{display:none}
.tab-panel.is-active{display:block;animation:shkfade .3s ease}

/* カードグリッド */
.card-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}

/* 人気ランキング（横スクロール） */
.rank-scroller{display:flex;gap:18px;overflow-x:auto;scroll-snap-type:x mandatory;padding:4px 2px 12px}
.rank-scroller::-webkit-scrollbar{height:8px}
.rank-scroller::-webkit-scrollbar-thumb{background:#d7e0e0;border-radius:99px}
.rank-scroller .card{flex:0 0 260px;scroll-snap-align:start;background:#fff;border:1px solid var(--shk-line);
  border-radius:var(--shk-radius);overflow:hidden;display:flex;flex-direction:column;transition:.18s;text-decoration:none;color:inherit}
.rank-scroller .card:hover{transform:translateY(-4px);box-shadow:var(--shk-shadow-lg)}
.rank-scroller .card .thumb{position:relative;aspect-ratio:16/10;overflow:hidden}
.rank-scroller .card .thumb img{width:100%;height:100%;object-fit:cover}
.rank-scroller .card .body{padding:14px}
.rank-scroller .card h3{margin:0;font-size:.98rem;line-height:1.5}

/* タグリンク */
.tag-links{display:flex;flex-wrap:wrap;gap:8px}
.tag-links a{font-size:.86rem;background:#fff;border:1px solid var(--shk-line);color:var(--shk-text-soft);
  padding:.45em 1em;border-radius:999px;text-decoration:none;transition:.15s}
.tag-links a:hover{background:var(--shk-accent);color:#fff;border-color:var(--shk-accent)}

/* 検索ボックス */
.search-box{display:flex;align-items:center;gap:8px;background:#fff;border:1px solid var(--shk-line);
  border-radius:999px;padding:5px 6px 5px 16px;box-shadow:var(--shk-shadow);min-width:280px}
.search-box input{border:0;outline:0;flex:1;min-width:0;font:inherit;font-size:.92rem;background:transparent}
.search-box button{flex:0 0 auto;border:0;border-radius:999px;background:var(--shk-accent);color:#fff;cursor:pointer;
  font-weight:700;font-size:.86rem;padding:.6em 1.2em}

@media(max-width:980px){
  .feature-grid{grid-template-columns:repeat(2,1fr)}
  .card-grid{grid-template-columns:repeat(2,1fr)}
  .shk-hero h1{font-size:2rem}
}
@media(max-width:640px){
  .feature-grid{grid-template-columns:1fr}
  .card-grid{grid-template-columns:1fr}
  .shk-hero h1{font-size:1.7rem}
  .search-box{width:100%;min-width:0}
  #shk-front .section-head h2{font-size:1.35rem}
}
