:root{
  --bg:#f4f6f9; --card:#ffffff; --ink:#16202c; --sub:#64748b; --line:#e6e9ef;
  --brand:#1d4ed8;          /* トラスト・ブルー（信頼） */
  --brand-ink:#1e40af; --brand-soft:#eef4ff;
  --cta:#f97316; --cta-ink:#ea580c;   /* 購入導線オレンジ（行動） */
  --gold:#d4a017; --silver:#9aa0a6; --bronze:#c17a3f;
  --chip:#f1f4f8; --up:#15863a; --down:#c0392b; --star:#f5a623;
  --max:920px; --shadow:0 1px 3px rgba(0,0,0,.06); --shadow-lg:0 10px 30px rgba(0,0,0,.12);
}
*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  margin:0;background:var(--bg);color:var(--ink);
  font-family:-apple-system,BlinkMacSystemFont,"Hiragino Sans","Noto Sans JP",sans-serif;
  line-height:1.8;font-size:16px;
}
a{color:var(--brand);text-decoration:none}
a:hover{text-decoration:underline}
.wrap{max-width:var(--max);margin:0 auto;padding:0 18px}

/* header */
.site-header{border-bottom:1px solid var(--line);position:sticky;top:0;background:rgba(255,255,255,.92);backdrop-filter:saturate(180%) blur(10px);z-index:20}
.site-header .wrap{display:flex;align-items:center;gap:20px;height:60px}
.logo{font-weight:800;font-size:21px;letter-spacing:.01em;color:var(--ink)}
.logo b{color:var(--brand)}
.nav{display:flex;gap:18px;font-size:14px;font-weight:700;margin-left:auto}
.nav a{color:var(--sub)}
.nav a:hover{color:var(--brand);text-decoration:none}

/* breadcrumb */
.breadcrumb{font-size:12px;color:var(--sub);padding-top:16px}
.breadcrumb a{color:var(--sub)}
.breadcrumb .sep{margin:0 7px;opacity:.5}

/* hero */
.article-hero{padding:14px 0 6px}
.article-hero h1{font-size:30px;line-height:1.4;margin:.25em 0 .35em;letter-spacing:-.01em}
.article-hero-meta{color:var(--sub);font-size:13px;display:flex;gap:9px;flex-wrap:wrap;align-items:center}
.article-hero-meta .dot{opacity:.45}
.updated{display:inline-flex;align-items:center;gap:5px;background:var(--brand-soft);color:var(--brand-ink);border:1px solid #f3d6d6;border-radius:999px;padding:2px 11px;font-weight:700}

/* lead + callout */
.lead{font-size:17px;color:#33363b;margin:18px 0 6px}
.callout{background:var(--brand-soft);border:1px solid #f3d6d6;border-left:4px solid var(--brand);border-radius:10px;padding:13px 17px;font-size:14px;color:#444;margin:20px 0}
.callout b{color:var(--brand-ink)}

h2{font-size:22px;margin:34px 0 12px;padding-left:13px;border-left:5px solid var(--brand);line-height:1.4}

/* comparison table */
.cmp-wrap{overflow-x:auto;margin:22px 0;border:1px solid var(--line);border-radius:12px;background:var(--card);box-shadow:var(--shadow)}
table.cmp{border-collapse:collapse;width:100%;font-size:14px;min-width:580px}
table.cmp th,table.cmp td{padding:11px 10px;text-align:left;vertical-align:middle}
table.cmp thead th{background:#2b2d31;color:#fff;font-weight:700;white-space:nowrap}
table.cmp tbody tr:nth-child(even){background:#fafbfc}
table.cmp tbody tr{border-top:1px solid var(--line)}
table.cmp td.num{text-align:right;white-space:nowrap;font-variant-numeric:tabular-nums}
.rank-badge{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;font-weight:800;color:#fff;background:#3a3d42;font-size:13px}
.rank-1{background:linear-gradient(135deg,#e8c45a,#caa017)}.rank-2{background:linear-gradient(135deg,#bcc1c7,#969ba1)}.rank-3{background:linear-gradient(135deg,#d39156,#b06a3b)}
.delta-up{color:var(--up);font-weight:700}.delta-down{color:var(--down);font-weight:700}
.delta-new{color:var(--brand);font-weight:800;font-size:11px;background:var(--brand-soft);padding:1px 6px;border-radius:4px}
.delta-flat{color:var(--sub)}

/* ranking item cards */
.item{display:flex;gap:18px;padding:18px;background:var(--card);border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow);margin-bottom:16px;position:relative}
.item--gold{border:1px solid #ecd9a0;box-shadow:0 3px 18px rgba(212,160,23,.16)}
.item--gold::before,.item--silver::before,.item--bronze::before{
  content:attr(data-medal);position:absolute;top:-11px;left:16px;font-size:11px;font-weight:800;color:#fff;
  padding:3px 11px;border-radius:999px;letter-spacing:.03em}
.item--gold::before{background:linear-gradient(135deg,#e8c45a,#caa017)}
.item--silver::before{background:linear-gradient(135deg,#bcc1c7,#969ba1)}
.item--bronze::before{background:linear-gradient(135deg,#d39156,#b06a3b)}
.item .thumb{flex:0 0 140px}
.item .thumb img{width:100%;height:auto;border-radius:10px;border:1px solid var(--line);background:#fff}
.item .body{flex:1;min-width:0}
.item h3{font-size:17px;margin:.15em 0 .5em;line-height:1.5}
.item .rk{font-size:12px;color:var(--sub);font-weight:700;margin-bottom:3px}
.meta-row{display:flex;gap:14px;flex-wrap:wrap;font-size:13px;color:var(--sub);margin:.5em 0;align-items:center}
.price{color:var(--brand-ink);font-weight:800;font-size:19px}
.stars{color:var(--star);letter-spacing:1px}
.btn{display:inline-flex;align-items:center;gap:6px;background:linear-gradient(180deg,#fb8a3c,#f97316);color:#fff!important;font-weight:800;padding:12px 24px;border-radius:10px;margin-top:10px;font-size:14.5px;box-shadow:0 3px 11px rgba(249,115,22,.34)}
.btn:hover{background:linear-gradient(180deg,#f97316,#ea580c);text-decoration:none;transform:translateY(-1px);box-shadow:0 5px 16px rgba(249,115,22,.42)}

/* card grid (silo index / top) */
.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:20px;margin:24px 0}
.card{background:var(--card);border:1px solid var(--line);border-radius:14px;overflow:hidden;box-shadow:var(--shadow);transition:transform .16s,box-shadow .16s;display:block;color:inherit}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);text-decoration:none}
.card-img{aspect-ratio:1200/630;overflow:hidden;background:#eef0f3}
.card-img img{width:100%;height:100%;object-fit:cover;display:block}
.card-body{padding:14px 16px}
.card-cat{font-size:11px;font-weight:800;color:var(--brand);letter-spacing:.05em;text-transform:uppercase}
.card-body h3{font-size:15.5px;line-height:1.5;margin:5px 0 7px;color:var(--ink)}
.card-body p{font-size:13px;color:var(--sub);margin:0;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}

/* 楽天サービスのバナー（PR） */
.promo{margin:30px 0;border:1px solid var(--line);border-radius:14px;background:#fff;box-shadow:var(--shadow);overflow:hidden}
.promo-head{font-size:12px;font-weight:700;color:var(--sub);padding:10px 16px;background:#fafbfc;border-bottom:1px solid var(--line);display:flex;align-items:center;gap:8px}
.promo-pr{font-size:10px;font-weight:800;color:#fff;background:var(--sub);border-radius:4px;padding:1px 6px;letter-spacing:.05em}
.promo-banners{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;align-items:center;padding:16px}
.promo-banner{max-width:100%}
.promo-banner img{max-width:100%;height:auto;display:block}

/* 自前デザインのリンクカード（生バナーの代わり） */
.link-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:10px;padding:14px}
.link-card{display:flex;align-items:center;gap:11px;padding:12px 14px;border:1px solid var(--line);border-radius:12px;background:#fff;color:inherit;box-shadow:var(--shadow);transition:transform .15s,box-shadow .15s,border-color .15s}
.link-card:hover{border-color:var(--cta);box-shadow:var(--shadow-lg);transform:translateY(-2px);text-decoration:none}
.link-card .lc-emoji{font-size:25px;line-height:1}
.link-card .lc-text{display:flex;flex-direction:column;min-width:0}
.link-card .lc-label{font-weight:800;font-size:14px;color:var(--ink)}
.link-card .lc-sub{font-size:11.5px;color:var(--sub)}
.link-card .lc-arrow{margin-left:auto;color:var(--cta);font-weight:900;font-size:18px}

/* 各商品の客観情報表 */
.spec{width:100%;border-collapse:collapse;font-size:13px;margin:8px 0 6px}
.spec th{text-align:left;color:var(--sub);font-weight:600;white-space:nowrap;width:72px;padding:6px 10px 6px 0;vertical-align:top;border-bottom:1px solid #f0f0f2}
.spec td{padding:6px 0;border-bottom:1px solid #f0f0f2}
.spec tr:last-child th,.spec tr:last-child td{border-bottom:none}
.spec small{color:var(--sub);font-size:11px;font-weight:600}
.spec .price{font-size:17px}
.soy{color:var(--gold);font-weight:700;font-size:11px;white-space:nowrap}

/* hero image */
.hero-wrap{margin:16px auto 0;max-width:var(--max);padding:0 18px}
.hero-img{width:100%;height:auto;border-radius:16px;box-shadow:var(--shadow);display:block}

/* native CTA（楽天カード） */
.native-cta{position:relative;margin:32px 0;padding:22px 22px 24px;border-radius:16px;border:1px solid #f0d98a;background:linear-gradient(135deg,#fff9ec,#fff4f4);box-shadow:var(--shadow)}
.native-cta-tag{position:absolute;top:14px;right:16px;font-size:10px;font-weight:800;color:#fff;background:var(--sub);border-radius:4px;padding:2px 7px;letter-spacing:.05em}
.native-cta h2{border:none;padding:0;margin:0 0 10px;font-size:20px}
.native-cta p{font-size:14.5px;color:#3a3a3a;margin:0 0 16px}
.btn-lg{font-size:16px;padding:14px 30px;border-radius:12px}

/* guide */
.guide{margin:32px 0}
.guide-list{list-style:none;padding:0;margin:0}
.guide-list li{position:relative;padding:10px 0 10px 30px;border-bottom:1px solid var(--line);font-size:14.5px;color:#3a3a3a}
.guide-list li::before{content:"✓";position:absolute;left:2px;top:10px;color:var(--brand);font-weight:800}
.guide-list li:last-child{border-bottom:none}

/* editor box */
.editor-box{display:flex;gap:14px;align-items:flex-start;margin:32px 0;padding:18px;border:1px solid var(--line);border-radius:14px;background:#fff;box-shadow:var(--shadow)}
.editor-avatar{flex:0 0 48px;width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,#e2222f,#a00d17);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:22px}
.editor-name{font-weight:800;margin-bottom:4px}
.editor-box p{font-size:13.5px;color:var(--sub);margin:0;line-height:1.7}

/* related */
.related{margin:38px 0 0}

/* 社会的証明（実データ由来） */
.badges{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:7px}
.badge{font-size:11px;font-weight:800;padding:3px 9px;border-radius:999px;white-space:nowrap;line-height:1.6}
.badge-hot{background:#fff1e6;color:#c2410c;border:1px solid #f8cda0}
.badge-pop{background:#fff3e0;color:#b06a00;border:1px solid #f0d8a8}
.badge-proof{background:#eef6ff;color:#1559b3;border:1px solid #cfe2f7}
.badge-soy{background:#fff8e1;color:#9a7400;border:1px solid #efe0a0}
.social-lead{font-size:14.5px;color:#2b3640;background:#f0f7ff;border-left:4px solid #3b82c4;border-radius:8px;padding:12px 16px;margin:14px 0}
.social-lead b{color:#1559b3}

/* 楽天セール告知バー */
.sale-bar{display:block;background:linear-gradient(90deg,#c4111d,#e2222f 60%,#f97316);color:#fff!important;text-align:center;padding:10px 16px;font-size:13.5px;font-weight:800;letter-spacing:.01em}
.sale-bar:hover{text-decoration:none;filter:brightness(1.05)}
.sale-bar .sale-tag{background:#ffe000;color:#a00;border-radius:4px;padding:1px 9px;margin-right:7px;font-size:12px}
.sale-bar .sale-when{background:rgba(255,255,255,.22);border-radius:4px;padding:1px 8px;margin-left:7px;font-weight:700}

/* 華やかセール告知（トップ） */
.sale-hero{display:flex;align-items:center;gap:16px;margin:18px 0 8px;padding:16px 20px;border-radius:16px;color:#fff!important;
  background:linear-gradient(120deg,#c4111d,#e2222f 38%,#f97316 72%,#ffb02e);box-shadow:0 6px 22px rgba(226,34,47,.32);position:relative;overflow:hidden}
.sale-hero::after{content:"";position:absolute;top:0;left:-60%;width:38%;height:100%;background:linear-gradient(100deg,transparent,rgba(255,255,255,.4),transparent);transform:skewX(-20deg);animation:shine 3.6s infinite}
@keyframes shine{0%{left:-60%}55%,100%{left:135%}}
.sale-hero:hover{text-decoration:none;transform:translateY(-1px)}
.sale-hero-emoji{font-size:34px;line-height:1}
.sale-hero-main{flex:1;min-width:0}
.sale-hero-title{font-size:21px;font-weight:900;letter-spacing:.01em}
.sale-hero-note{font-size:13.5px;opacity:.97;margin:2px 0}
.sale-hero-when{font-size:13px;font-weight:800;background:rgba(0,0,0,.2);display:inline-block;padding:2px 11px;border-radius:999px;margin-top:3px}
.sale-hero-btn{background:#fff;color:#c4111d;font-weight:900;padding:12px 22px;border-radius:11px;white-space:nowrap;font-size:14.5px;box-shadow:0 3px 10px rgba(0,0,0,.16)}
.sale-promo{border-color:#f6c8a8!important}
.sale-promo .promo-head{background:linear-gradient(90deg,#fff1e8,#ffe9e9);color:#c4111d}
@media(max-width:560px){.sale-hero{flex-wrap:wrap}.sale-hero-btn{width:100%;text-align:center}}

/* 編集記事（フラッグシップ） */
.review{margin:38px 0}
.review>h2{font-size:23px}
.review-lead{font-size:15px;color:#33363b;margin:0 0 18px}
.review-item{border:1px solid var(--line);border-radius:14px;background:#fff;box-shadow:var(--shadow);padding:18px 20px;margin-bottom:18px}
.review-item h3{font-size:18px;margin:0 0 14px;line-height:1.5}
.pros-cons{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:13px}
.pros,.cons{border-radius:10px;padding:12px 15px}
.pros{background:#f0faf3;border:1px solid #cdeed7}
.cons{background:#fef3f2;border:1px solid #f6d6d2}
.pros h4,.cons h4{margin:0 0 8px;font-size:14px}
.pros h4{color:#15863a}.cons h4{color:#c0392b}
.pros ul,.cons ul{margin:0;padding-left:18px;font-size:13.5px;color:#3a3a3a}
.pros li,.cons li{margin-bottom:7px;line-height:1.65}
.rivals{font-size:13.5px;color:#3a3a3a;background:#f6f8fb;border-left:4px solid var(--brand);border-radius:8px;padding:11px 14px;margin:0;line-height:1.7}
.rivals span{font-weight:700;color:var(--ink)}
.verdict{margin:22px 0 0;border:2px solid var(--cta);border-radius:14px;background:linear-gradient(135deg,#fff8f1,#fff4ec);padding:18px 20px}
.verdict-tag{display:inline-block;background:var(--cta);color:#fff;font-weight:800;font-size:13.5px;padding:5px 14px;border-radius:999px;margin-bottom:11px}
.verdict p{font-size:14.5px;color:#33363b;margin:0 0 10px;line-height:1.8}
.verdict p:last-child{margin-bottom:0}
.review-note{font-size:11.5px;color:var(--sub);margin:14px 0 0}
/* 図解型レビュー（画像＋レーダー＋リンク） */
.ri-head{display:flex;gap:14px;align-items:center;margin-bottom:14px}
.ri-thumb{flex:0 0 88px;width:88px;height:88px;border:1px solid var(--line);border-radius:10px;overflow:hidden;background:#fff;display:block}
.ri-thumb img{width:100%;height:100%;object-fit:contain}
.ri-headtext{flex:1;min-width:0}
.ri-name{font-size:17px;font-weight:800;line-height:1.4}
.ri-tag{font-size:13px;color:var(--sub);margin:2px 0 9px}
.ri-btn{margin-top:0}
.ri-body{display:flex;gap:18px;align-items:center;flex-wrap:wrap;margin-bottom:12px}
.ri-radar{flex:0 0 auto;text-align:center}
.radar{display:block;max-width:100%;height:auto}
.ri-radar-cap{font-size:11px;color:var(--sub);margin-top:2px}
.ri-pc{flex:1;min-width:240px;display:grid;grid-template-columns:1fr 1fr;gap:12px}
.ri-pc .pros,.ri-pc .cons{margin:0}
.ri-name a{color:inherit;text-decoration:none}
.ri-name a:hover{color:var(--brand);text-decoration:underline}
.rivals a{color:var(--brand);font-weight:700;text-decoration:underline}
/* 編集長おすすめ（シーン別） */
.verdict-list{list-style:none;padding:0;margin:6px 0 0}
.verdict-list li{padding:11px 0;border-top:1px solid #f3dcc4}
.verdict-list li:first-child{border-top:none}
.v-scene{font-weight:700;color:#33363b}
.v-arrow{color:var(--cta);font-weight:900;margin:0 7px}
.v-pick{font-weight:800;color:var(--cta-ink);text-decoration:underline}
.v-why{display:block;color:var(--sub);font-size:12.5px;margin-top:3px}
@media(max-width:560px){.pros-cons{grid-template-columns:1fr}.ri-pc{grid-template-columns:1fr}.ri-body{justify-content:center}}

/* disclosure */
.ad-note{font-size:12px;color:var(--sub);margin:8px 0 0}
.ad-note a{color:var(--sub);text-decoration:underline}
.pr-disclosure{font-size:12px;color:var(--sub);margin:26px 0 0;padding-top:14px;border-top:1px solid var(--line)}
.pr-disclosure a{color:var(--sub);text-decoration:underline}

/* footer */
.site-footer{border-top:1px solid var(--line);margin-top:48px;padding:30px 0;color:var(--sub);font-size:13px;background:#fff}
.site-footer a{color:var(--sub)}

@media(max-width:560px){
  body{font-size:15px}
  .article-hero h1{font-size:24px}
  h2{font-size:19px}
  .item{padding:15px;gap:13px}
  .item .thumb{flex-basis:104px}
  .price{font-size:17px}
  .nav{gap:13px}
  .card-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:13px}
}
