/*
Theme Name: 買えた (kaeta.net)
Description: 「商品名＋予約方法」を量産する予約・抽選案内サイト「買えた」用テーマ。資格一覧.comの構成を流用。CPT=item / taxonomy=item_brand,item_type。
Version: 0.2.0
Text Domain: kaeta
*/

/* ===== トークン ===== */
:root{
  --accent:#ff5630;        /* 買えた＝お得・行動を促す暖色 */
  --accent-dark:#e23e1c;
  --ink:#1f2430;
  --sub:#5b6472;
  --line:#e7e9ee;
  --bg:#f6f7f9;
  --card:#ffffff;
  --open:#1e9e5a;          /* 受付中 */
  --closed:#8a93a2;        /* 受付終了 */
  --upcoming:#2f6fed;      /* 開始前 */
  --unknown:#d99100;       /* 確認中 */
  --radius:12px;
  --shadow:0 1px 3px rgba(20,30,50,.06),0 6px 20px rgba(20,30,50,.05);
}
*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  margin:0;color:var(--ink);background:var(--bg);
  font-family:-apple-system,BlinkMacSystemFont,"Hiragino Kaku Gothic ProN","Noto Sans JP","Yu Gothic",Meiryo,sans-serif;
  line-height:1.8;font-size:16px;
}
a{color:var(--accent-dark);text-decoration:none}
a:hover{text-decoration:underline}
img{max-width:100%;height:auto}
.container{width:100%;max-width:820px;margin:0 auto;padding:0 16px}

/* ===== ヘッダー / フッター ===== */
.site-header{background:var(--card);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:20}
.site-header .container{display:flex;align-items:center;justify-content:space-between;gap:16px;height:58px}
.site-logo{font-weight:800;font-size:1.35rem;color:var(--ink);letter-spacing:.02em}
.site-logo:hover{text-decoration:none;color:var(--accent-dark)}
.global-nav ul,.footer-nav ul{list-style:none;display:flex;gap:18px;margin:0;padding:0;flex-wrap:wrap}
.global-nav a{color:var(--sub);font-size:.9rem;font-weight:600}
.site-footer{background:#fff;border-top:1px solid var(--line);margin-top:48px;padding:28px 0;color:var(--sub);font-size:.85rem}
.site-footer .copyright{margin:.5rem 0 0}

/* ===== 本文レイアウト ===== */
.site-main{padding:24px 0 8px}
.single-item .article,.page-calendar,.page .page-body{
  background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow);padding:28px 24px;margin:0 auto 24px;max-width:820px;
}
.page-calendar,.site-main>h1{max-width:820px;margin-left:auto;margin-right:auto}

h1{font-size:1.6rem;line-height:1.4;margin:.2em 0 .6em;font-weight:800}
h2{font-size:1.25rem;margin:1.8em 0 .6em;padding-left:12px;border-left:5px solid var(--accent);font-weight:800}
h3{font-size:1.08rem;margin:1.4em 0 .4em}
p{margin:.7em 0}

/* パンくず */
.breadcrumb{font-size:.8rem;color:var(--sub);margin:0 auto 14px;max-width:820px}
.breadcrumb ol{list-style:none;display:flex;flex-wrap:wrap;gap:6px;margin:0;padding:0}
.breadcrumb li+li::before{content:"›";margin-right:6px;color:#b9c0cc}

/* ===== 受付ステータス バッジ ===== */
.reserve-status{display:flex;align-items:center;gap:12px;flex-wrap:wrap;
  padding:12px 16px;border-radius:10px;font-size:1rem;margin:.4em 0 1em;background:#f2f4f7}
.reserve-status strong{font-size:1.05rem}
.reserve-status::before{content:"";width:10px;height:10px;border-radius:50%;background:var(--sub)}
.reserve-status.is-open{background:#e8f7ee;color:#0f7a42}
.reserve-status.is-open::before{background:var(--open)}
.reserve-status.is-closed{background:#eef0f3;color:#5b6472}
.reserve-status.is-closed::before{background:var(--closed)}
.reserve-status.is-upcoming{background:#eaf1ff;color:#1d4fc4}
.reserve-status.is-upcoming::before{background:var(--upcoming)}
.reserve-status.is-unknown{background:#fff6e5;color:#9a6a00}
.reserve-status.is-unknown::before{background:var(--unknown)}
.days-left{margin-left:auto;background:var(--accent);color:#fff;font-weight:700;font-size:.85rem;padding:3px 10px;border-radius:999px}
.lead{font-size:1.02rem;color:#3a4150}

/* ===== テーブル ===== */
table{border-collapse:collapse;width:100%;margin:1em 0;font-size:.95rem}
.item-summary th,.item-summary td{text-align:left;padding:11px 14px;border-bottom:1px solid var(--line);vertical-align:top}
.item-summary th{width:34%;background:#f7f8fa;color:var(--sub);font-weight:700;white-space:nowrap}
.store-table thead th,.cal-table thead th{background:#2b3340;color:#fff;font-weight:700;padding:10px 12px;text-align:left;font-size:.85rem}
.store-table td,.cal-table td{padding:10px 12px;border-bottom:1px solid var(--line)}
.store-table tbody tr:nth-child(even),.cal-table tbody tr:nth-child(even){background:#fafbfc}
.store-table a,.cal-table a{font-weight:600}

/* 手順 */
.howto-steps{counter-reset:s;list-style:none;padding:0;margin:1em 0}
.howto-steps li{position:relative;padding:14px 16px 14px 54px;margin:0 0 10px;background:#f8f9fb;border-radius:10px}
.howto-steps li::before{counter-increment:s;content:counter(s);position:absolute;left:14px;top:14px;
  width:28px;height:28px;border-radius:50%;background:var(--accent);color:#fff;font-weight:800;
  display:flex;align-items:center;justify-content:center;font-size:.9rem}

/* FAQ */
.faq dt{font-weight:700;margin:1em 0 .2em;padding-left:24px;position:relative}
.faq dt::before{content:"Q";position:absolute;left:0;color:var(--accent);font-weight:800}
.faq dd{margin:0 0 .8em 24px;color:#3a4150}

/* リアルな声 / 体験談 */
.voices{margin:1em 0}
.voice{background:#fff;border:1px solid var(--line);border-left:4px solid var(--accent);
  border-radius:8px;padding:12px 16px;margin:0 0 10px;color:#3a4150;font-size:.95rem}
.voice .voice-meta{display:block;color:var(--sub);font-size:.78rem;margin-top:6px}

/* 過去の実績 / 相場 */
.past-results{background:#fbfbfd;border:1px dashed #d6dae2;border-radius:10px;padding:6px 18px;margin:1em 0}
.notes{background:#fff8f6;border:1px solid #ffd9cf;border-radius:10px;padding:6px 18px;margin:1em 0}

/* CTA / アフィリ */
.btn{display:inline-block;font-weight:800;text-align:center;border-radius:10px;padding:14px 22px;
  text-decoration:none;transition:.15s}
.btn:hover{text-decoration:none;transform:translateY(-1px)}
.btn-accent{background:var(--accent);color:#fff;box-shadow:0 4px 14px rgba(255,86,48,.3)}
.btn-accent:hover{background:var(--accent-dark);color:#fff}
.btn-block{display:block;width:100%}
.affiliate-cta{margin:1.6em 0;text-align:center}
.official-link{font-size:.85rem;color:var(--sub)}

/* カレンダー */
.cal-note{color:var(--sub);font-size:.85rem}
.cal-section{margin:1.6em 0}
.cal-section h2{font-size:1.1rem}

/* 一覧 */
.post-list{list-style:none;padding:0}
.post-list li{background:#fff;border:1px solid var(--line);border-radius:10px;padding:14px 16px;margin:0 0 10px}

/* ===== 網羅版：商品ページ専用レイアウト ===== */
body.single-item .container{max-width:1080px}

/* ヒーロー */
.item-hero{background:linear-gradient(180deg,#fff 0%,#fbfcfe 100%);border-bottom:1px solid var(--line);padding:8px 0 24px}
.item-hero h1{font-size:1.7rem;margin:.3em 0 .5em}
.hero-badges{display:flex;gap:8px;flex-wrap:wrap;margin:.2em 0 .8em}
.badge{display:inline-block;font-size:.78rem;font-weight:700;padding:4px 11px;border-radius:999px;background:#eef1f5;color:#445}
.badge-method{background:#ffe9e3;color:#c23e1c}
.badge-status.is-open{background:#e8f7ee;color:#0f7a42}
.badge-status.is-closed{background:#eef0f3;color:#5b6472}
.badge-status.is-upcoming{background:#eaf1ff;color:#1d4fc4}
.badge-status.is-unknown{background:#fff6e5;color:#9a6a00}
.badge.diff-5{background:#ffe0e0;color:#c0263a}.badge.diff-4{background:#ffe9da;color:#bd5a14}
.badge.diff-3{background:#fff3d6;color:#9a7400}.badge.diff-2{background:#e6f3e9;color:#2c7a4b}
.hero-lead{font-size:1.02rem;color:#3a4150;max-width:760px}
.hero-grid{display:grid;grid-template-columns:1fr 240px;gap:16px;margin-top:16px}
.keydata-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}
.keydata{background:#fff;border:1px solid var(--line);border-radius:10px;padding:12px 10px;text-align:center}
.keydata .label{font-size:.72rem;color:var(--sub);margin-bottom:4px}
.keydata .value{font-size:1.5rem;font-weight:800;line-height:1.1;color:var(--ink)}
.keydata .value.sm{font-size:1rem}
.keydata .value small{font-size:.7rem;font-weight:600;color:var(--sub);margin-left:2px}
.score-panel{background:#2b3340;color:#fff;border-radius:12px;padding:14px 16px;display:flex;flex-direction:column;justify-content:center}
.score-panel .label{font-size:.74rem;opacity:.85}
.score-panel .est,.keydata .est{font-size:.62rem;opacity:.7}
.score-panel .score{font-size:2.1rem;font-weight:800;line-height:1}
.score-panel .score small{font-size:.8rem;opacity:.8;font-weight:600}
.score-panel .breakdown{display:flex;gap:14px;margin:8px 0 4px;font-size:.74rem}
.score-panel .breakdown span{display:inline-block;margin-left:4px;font-weight:800;color:var(--accent)}
.score-panel .est-note{font-size:.62rem;opacity:.65;margin-top:4px}

/* 2カラムレイアウト */
.layout{display:grid;grid-template-columns:1fr 300px;gap:28px;align-items:start;padding-top:24px}
.layout .article{padding:28px 26px}
.sidebar .card{background:#fff;border:1px solid var(--line);border-radius:12px;padding:18px 16px;box-shadow:var(--shadow)}
.sidebar .sticky{position:sticky;top:74px}
.sidebar h3{font-size:.95rem;margin:.2em 0 .6em}
.mini-list{list-style:none;padding:0;margin:0 0 12px;font-size:.86rem}
.mini-list li{border-bottom:1px dashed var(--line);padding:7px 0}
.mini-list a{color:#3a4150}
.countdown{background:var(--accent);color:#fff;border-radius:8px;text-align:center;padding:8px;margin:0 0 12px;font-size:.85rem}
.countdown strong{display:block;font-size:1.15rem}

/* 目次 */
.toc{background:#f7f9fb;border:1px solid var(--line);border-radius:12px;padding:14px 18px;margin:0 0 22px}
.toc-title{font-weight:800;margin-bottom:6px}
.toc ol{margin:0;padding-left:1.2em;color:#3a4150}
.toc li{margin:4px 0}

/* 基本データ表 */
.data-table{width:100%}
.data-table th,.data-table td{text-align:left;padding:11px 14px;border-bottom:1px solid var(--line);vertical-align:top}
.data-table th{width:30%;background:#f7f8fa;color:var(--sub);font-weight:700;white-space:nowrap}
.table-scroll{overflow-x:auto}

/* 関連カード */
.related-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:10px;margin:1em 0}
.related-card{display:flex;flex-direction:column;gap:4px;background:#fff;border:1px solid var(--line);border-radius:10px;padding:12px 14px;text-decoration:none;color:var(--ink)}
.related-card:hover{border-color:var(--accent);text-decoration:none}
.related-card .name{font-weight:700;font-size:.92rem}
.related-card .meta{font-size:.75rem;color:var(--sub)}

/* 出典・注記 */
.source-box{background:#f7f9fb;border:1px solid var(--line);border-radius:10px;padding:12px 16px;margin:1.4em 0;font-size:.85rem;color:#3a4150}
.source-box .source-meta{color:var(--sub)}
.data-disclaimer{background:#fbfbfd;border:1px dashed #d6dae2;border-radius:10px;padding:12px 16px;margin:1.2em 0;font-size:.8rem;color:var(--sub);line-height:1.7}
.data-disclaimer .updated{display:block;margin-top:6px;font-size:.74rem}
.cta-box{margin:1.6em 0;text-align:center}

/* レスポンシブ */
@media(max-width:880px){
  .hero-grid{grid-template-columns:1fr}
  .layout{grid-template-columns:1fr}
  .sidebar{order:2}
  .sidebar .sticky{position:static}
}
@media(max-width:640px){
  body{font-size:15px}
  h1,.item-hero h1{font-size:1.32rem}
  .single-item .article,.page-calendar,.layout .article{padding:18px 15px}
  .item-summary th,.data-table th{width:40%}
  .keydata-grid{grid-template-columns:repeat(2,1fr)}
  .keydata .value{font-size:1.25rem}
  .reserve-status{font-size:.95rem}
  .days-left{margin-left:0}
}
