:root{
  /* 誌面/批評(明朝)の方向に合わせた「ワインのダーク+ガーネット」系。
     クール near-black + 旧Twitterローズの既視感を避けつつ、vermilion-on-near-black の
     定番化も避ける。アクセントは rgb(209,20,80)。 */
  --bg:#121017; --surface:#1b1825; --text:#e8e8ea; --muted:#9aa0aa;
  --accent:#d11450; --border:#2c2735; --maxw:1140px; --gold:#e6b422;
  /* 見出し用ディスプレイ書体(明朝)。本文ゴシックと対比させ「批評/エディトリアル」の人格を出す */
  --font-display:"Shippori Mincho","Hiragino Mincho ProN","Yu Mincho",serif;
}
@media (prefers-color-scheme: light){
  :root{ --bg:#ffffff; --surface:#f6f7f9; --text:#1a1a1a; --muted:#666; --border:#e3e6ea; }
}
*{box-sizing:border-box}
body{margin:0;font-family:-apple-system,"Hiragino Kaku Gothic ProN","Yu Gothic",sans-serif;
  background:var(--bg);color:var(--text);line-height:1.8}
a{color:var(--accent);text-decoration:none}
a:hover{text-decoration:underline}
.container{max-width:var(--maxw);margin:0 auto;padding:0 20px}
/* 2-column desktop layout (flexbox・nowrap・固定basis=全ブラウザ互換) */
/* padding は .container の左右20pxを維持しつつ上下を調整(0にすると本文/パンくずが枠外へ出る) */
.layout{display:flex;flex-wrap:nowrap;gap:36px;align-items:flex-start;padding:8px 20px 24px}
.content{flex:1 1 0%;min-width:0}
.side-rail{flex:0 0 300px;width:300px;position:sticky;top:76px}
.panel{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:16px 18px;margin-bottom:20px}
.panel-title{margin:0 0 12px;font-size:.95rem;border-left:4px solid var(--accent);padding-left:10px}
.mini-list{list-style:none;margin:0;padding:0}
.mini-list li{display:flex;gap:10px;align-items:center;margin:0 0 12px}
.mini-thumb{display:block;width:64px;height:42px;flex-shrink:0;border-radius:6px;background:#000 center/cover no-repeat}
.mini-title{font-size:.82rem;line-height:1.4;color:var(--text)}
/* サイドバーのX(Twitter)スレッド埋め込み */
.x-panel{padding:12px}
.x-panel .twitter-tweet{margin:0 auto!important}
.x-panel iframe{max-width:100%!important}
.tagcloud{display:flex;flex-wrap:wrap;gap:6px}
.tagcloud a{background:var(--bg);border:1px solid var(--border);color:var(--muted);font-size:.73rem;padding:2px 9px;border-radius:999px;line-height:1.5}
.tagcloud a:hover{color:var(--text);text-decoration:none;border-color:var(--accent)}
.panel-more{display:inline-block;margin-top:10px;font-size:.74rem;color:var(--accent);font-weight:700}
/* タグ・女優一覧ページ(/tags/) */
.tags-h1{font-family:var(--font-display);font-weight:700;font-size:1.5rem;margin:28px 0 14px;border-left:4px solid var(--accent);padding-left:12px}
.tagcloud-lg{gap:8px;padding:4px 0 8px}
.tagcloud-lg a{font-size:.86rem;padding:5px 13px}
.tagcloud-lg a small{margin-left:5px;opacity:.55;font-weight:600}
@media (max-width:900px){
  .layout{flex-wrap:wrap}
  .side-rail{flex:1 1 100%;width:100%;position:static}
}
/* header */
.site-header{position:sticky;top:0;z-index:10;background:color-mix(in srgb,var(--bg) 88%,transparent);
  -webkit-backdrop-filter:saturate(180%) blur(8px);backdrop-filter:saturate(180%) blur(8px);border-bottom:1px solid var(--border)}
.site-header .container{display:flex;align-items:center;justify-content:space-between;height:56px}
.brand{font-family:var(--font-display);font-weight:700;font-size:1.2rem;color:var(--text);letter-spacing:.04em}
.brand span{color:var(--accent)}
.nav{display:flex;align-items:center;gap:18px;overflow-x:auto;max-width:72%;scrollbar-width:none}
.nav::-webkit-scrollbar{display:none}
.nav a{color:var(--muted);font-size:.92rem;font-weight:600;white-space:nowrap;flex-shrink:0}
.nav a:hover{color:var(--text)}
/* 開催中ASPキャンペーン帯(nav下・全ページ共通・日次更新) */
.campaign-strip{display:flex;align-items:center;gap:12px;padding:8px 20px;max-width:var(--maxw);margin:0 auto;
  background:linear-gradient(90deg,rgba(209,20,80,.18),rgba(209,20,80,.04));border-bottom:1px solid var(--border);
  color:var(--text);font-size:.85rem;overflow:hidden}
.campaign-strip:hover{text-decoration:none;background:linear-gradient(90deg,rgba(209,20,80,.26),rgba(209,20,80,.08))}
.campaign-tag{flex-shrink:0;background:var(--accent);color:#fff;font-weight:800;font-size:.74rem;padding:3px 9px;border-radius:6px;white-space:nowrap}
.campaign-names{font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.campaign-cta{margin-left:auto;flex-shrink:0;color:var(--accent);font-weight:800;white-space:nowrap}
/* article */
article{padding:24px 0 4px}
article h1{font-family:var(--font-display);font-size:1.85rem;font-weight:700;line-height:1.4;margin:0 0 12px}
article h2{font-family:var(--font-display);font-size:1.4rem;font-weight:700;margin:36px 0 12px;border-left:4px solid var(--accent);padding-left:12px}
article h3{font-family:var(--font-display);font-size:1.18rem;font-weight:600;margin:28px 0 10px}
article p{margin:14px 0}
article img{max-width:100%;height:auto;border-radius:10px;margin:18px auto;display:block}
.body-img{display:block;text-align:center}
.body-img img{margin:18px auto}
article ul,article ol{padding-left:1.4em}
.cta a,a.cta{display:inline-block;background:var(--accent);color:#fff;padding:12px 26px;border-radius:999px;
  font-weight:700;margin:10px 0}
.cta a:hover,a.cta:hover{text-decoration:none;opacity:.92}
.breadcrumb{font-size:.82rem;color:var(--muted);padding:14px 0 0}
.meta{font-size:.82rem;color:var(--muted);margin:4px 0 18px}
.tags{margin:18px 0}
.tags a{display:inline-block;background:var(--surface);border:1px solid var(--border);color:var(--muted);
  font-size:.78rem;padding:4px 12px;border-radius:999px;margin:0 6px 6px 0}
/* cards / lists */
.hero{padding:18px 0 14px;border-bottom:1px solid var(--border);margin-bottom:18px}
.hero h1{font-family:var(--font-display);font-weight:700;font-size:1.5rem;line-height:1.4;margin:0 0 6px}
.hero p{color:var(--muted);font-size:.9rem;margin:0}
/* ===== 注目の新作ヒーロー(シグネチャー: 表紙+明朝タイトルで誌面的に開く) ===== */
.hero-feature{margin:18px 0 26px;border-bottom:1px solid var(--border);padding-bottom:24px}
.hero-h1{font-family:var(--font-display);font-weight:600;font-size:1.12rem;line-height:1.5;
  color:var(--muted);letter-spacing:.01em;margin:0 0 14px}
.hero-card{display:flex;background:var(--surface);border:1px solid var(--border);border-radius:16px;
  overflow:hidden;text-decoration:none;color:inherit;transition:border-color .15s,box-shadow .15s,transform .15s}
.hero-card:hover{border-color:var(--accent);box-shadow:0 14px 40px rgba(0,0,0,.4);transform:translateY(-2px);text-decoration:none}
.hero-card.on-sale{border-color:var(--gold);background:color-mix(in srgb,var(--gold) 7%,var(--surface))}
.hero-thumb{position:relative;flex:0 0 46%;max-width:46%;aspect-ratio:16/10;background:#000 center/cover no-repeat}
.hero-card:hover .hero-thumb{filter:brightness(1.05)}
.hero-play{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:64px;height:64px;
  border-radius:50%;background:rgba(209,20,80,.92);color:#fff;display:flex;align-items:center;
  justify-content:center;font-size:1.6rem;padding-left:5px;box-shadow:0 4px 18px rgba(0,0,0,.45);transition:transform .15s}
.hero-card:hover .hero-play{transform:translate(-50%,-50%) scale(1.08)}
.hero-text{flex:1;min-width:0;padding:24px 28px;display:flex;flex-direction:column;justify-content:center}
.hero-eyebrow{display:inline-flex;align-items:center;gap:9px;font-size:.72rem;font-weight:800;letter-spacing:.16em;color:var(--accent);margin-bottom:9px}
.hero-date{font-weight:700;letter-spacing:.04em;color:var(--muted);font-variant-numeric:tabular-nums}
.hero-title{font-family:var(--font-display);font-weight:700;font-size:1.72rem;line-height:1.42;margin:0;color:var(--text);
  display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.hero-actress{color:var(--accent);font-size:.9rem;font-weight:600;margin:9px 0 0}
.hero-desc{color:var(--muted);font-size:.92rem;line-height:1.7;margin:10px 0 0;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.hero-cta{margin-top:18px;align-self:flex-start;background:var(--accent);color:#fff;font-weight:800;
  font-size:.92rem;padding:10px 24px;border-radius:999px}
.hero-card:hover .hero-cta{opacity:.93}
@media(max-width:680px){
  .hero-card{flex-direction:column}
  .hero-thumb{flex:0 0 auto;max-width:none;width:100%;aspect-ratio:16/9}
  .hero-text{padding:18px 18px 20px}
  .hero-title{font-size:1.42rem}
}
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:18px;padding:8px 0 48px}
/* 固定3列(ホームのSALE/新着/人気)。狭幅で2列→1列 */
.grid.cols3{grid-template-columns:repeat(3,1fr)}
@media(max-width:760px){.grid.cols3{grid-template-columns:repeat(2,1fr)}}
@media(max-width:480px){.grid.cols3{grid-template-columns:1fr}}
/* SALEバッジ(カードのサムネ左上) */
.sale-badge{position:absolute;top:8px;left:8px;background:var(--gold);color:#1a1200;font-weight:800;
  font-size:.72rem;letter-spacing:.04em;padding:3px 9px;border-radius:6px;box-shadow:0 1px 4px rgba(0,0,0,.4)}
.sale-badge.big{top:0;left:0;border-radius:0 0 10px 0;padding:6px 12px;font-size:1.05rem;font-weight:900;
  display:flex;align-items:baseline;gap:1px;box-shadow:0 2px 10px rgba(230,180,34,.55)}
.sale-badge.big small{font-size:.6rem;font-weight:800}
.new-badge{position:absolute;top:8px;right:8px;background:var(--accent);color:#fff;font-weight:900;
  font-size:.66rem;letter-spacing:.07em;padding:3px 8px;border-radius:6px;box-shadow:0 1px 4px rgba(0,0,0,.45);z-index:2}
.sale-until{color:var(--gold);font-size:.7rem;font-weight:600;margin-right:auto}
/* セール中カード: 枠はゴールド(hoverのaccentと区別)+薄い金背景 */
.card.on-sale{border-color:var(--gold);
  background:color-mix(in srgb, var(--gold) 7%, var(--surface));
  box-shadow:0 4px 16px rgba(230,180,34,.16)}
.card.on-sale:hover{box-shadow:0 8px 24px rgba(230,180,34,.30)}
/* セール価格: ¥定価(打消) → ¥セール円 */
.card-price{margin:0 0 6px;display:flex;align-items:baseline;flex-wrap:wrap;gap:5px}
.card-was{color:var(--muted);text-decoration:line-through;font-size:.85rem}
.card-arrow{color:var(--muted);font-size:.85rem}
.card-now{color:var(--accent);font-weight:900;font-size:1.25rem}
.card-now small{font-size:.72rem;font-weight:800;margin-left:1px}
/* ホームのSALEセクション見出し */
.section-title.sale{color:var(--accent)}
.section-title.sale::before{content:"🔥 "}
/* 記事内セールバナー(値引き率・価格を目立たせる) */
.sale-banner{display:flex;align-items:center;gap:16px;flex-wrap:wrap;margin:20px 0;padding:14px 18px;
  border-radius:12px;background:linear-gradient(90deg,rgba(209,20,80,.18),rgba(209,20,80,.06));
  border:1px solid var(--accent);color:var(--text)}
.sale-banner:hover{text-decoration:none;background:linear-gradient(90deg,rgba(209,20,80,.26),rgba(209,20,80,.1))}
.sale-off{flex-shrink:0;background:var(--accent);color:#fff;font-weight:900;font-size:1.5rem;line-height:1;
  padding:8px 12px;border-radius:10px;display:flex;align-items:baseline;gap:2px;box-shadow:0 2px 8px rgba(209,20,80,.4)}
.sale-off small{font-size:.7rem;font-weight:800}
.sale-banner-tag{background:var(--accent);color:#fff;font-weight:800;font-size:.85rem;padding:6px 12px;border-radius:8px;white-space:nowrap}
.sale-banner-main{display:flex;align-items:baseline;gap:10px;flex-wrap:wrap}
.sale-now{color:var(--accent);font-weight:900;font-size:1.4rem}
.sale-was{color:var(--muted);text-decoration:line-through;font-size:.95rem}
.sale-banner-text{font-weight:700;font-size:.9rem;flex-basis:100%}
.sale-banner-cta{margin-left:auto;color:var(--accent);font-weight:800;font-size:.9rem;white-space:nowrap}
/* ページネーション */
.pager{display:flex;gap:8px;justify-content:center;flex-wrap:wrap;padding:8px 0 40px}
.pager a,.pager span{min-width:38px;text-align:center;padding:7px 12px;border-radius:8px;
  border:1px solid var(--border);color:var(--muted);font-size:.88rem;font-weight:600}
.pager a:hover{color:#fff;background:var(--accent);border-color:var(--accent);text-decoration:none}
.pager .current{color:#fff;background:var(--accent);border-color:var(--accent)}
.card{background:var(--surface);border:1px solid var(--border);border-radius:12px;overflow:hidden;
  display:flex;flex-direction:column;transition:transform .15s,border-color .15s;
  text-decoration:none;color:inherit}
.card:hover{transform:translateY(-3px);border-color:var(--accent);text-decoration:none}
/* 新着=横長フィーチャーカード(記事一覧の小カードと区別。画像+title2行+desc枠内) */
.feature-list{display:flex;flex-direction:column;gap:16px;padding:8px 0 16px}
.feature-card{display:flex;gap:0;background:var(--surface);border:1px solid var(--border);border-radius:14px;overflow:hidden;text-decoration:none;color:inherit;transition:border-color .15s,box-shadow .15s}
.feature-card:hover{border-color:var(--accent);box-shadow:0 6px 22px rgba(0,0,0,.28)}
.feature-card.on-sale{border-color:var(--gold);background:color-mix(in srgb, var(--gold) 6%, var(--surface))}
.feature-thumb{position:relative;flex:0 0 34%;max-width:34%;aspect-ratio:16/10;background:#0c0c0c center/cover no-repeat}
.feature-card:hover .feature-thumb{filter:brightness(1.06)}
.feature-body{flex:1;min-width:0;padding:14px 18px;display:flex;flex-direction:column}
.feature-title{margin:0 0 8px;font-size:1.12rem;line-height:1.45;font-weight:700;color:var(--text);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.feature-card:hover .feature-title{text-decoration:underline}
.feature-desc{margin:0;color:var(--muted);font-size:.9rem;line-height:1.7;overflow:hidden;flex:1}
.feature-date{margin-top:8px;color:var(--muted);font-size:.72rem}
@media(max-width:560px){.feature-card{flex-direction:column}.feature-thumb{flex:0 0 auto;max-width:none;width:100%;aspect-ratio:16/9}.feature-body{padding:12px 14px}}
.card .thumb{position:relative;aspect-ratio:16/9;background:#0c0c0c center/cover no-repeat;overflow:hidden}
.card:hover .thumb{filter:brightness(1.07)}
.card:hover .card-title{text-decoration:underline}
.rank-badge{position:absolute;top:8px;left:8px;width:30px;height:30px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;font-weight:800;font-size:.95rem;
  background:rgba(0,0,0,.5);color:#fff}
.card .body{padding:14px 16px;display:flex;flex-direction:column;flex:1}
.card-title{margin:0 0 6px;font-size:1.0rem;line-height:1.4;color:var(--text);
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.card-actress{margin:0 0 6px;color:var(--accent);font-size:.78rem;font-weight:600}
.card .desc{margin:0;color:var(--muted);font-size:.83rem;line-height:1.5;
  display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.card-foot{margin-top:auto;padding-top:10px;display:flex;justify-content:flex-end}
.card-date{color:var(--muted);font-size:.7rem}
/* article footer: tags(capsule) + date */
.article-footer{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px;
  margin:12px 0 0;padding-top:12px;border-top:1px solid var(--border)}
.article-footer .tags{display:flex;flex-wrap:wrap;gap:8px}
.tag-cap{background:var(--surface);border:1px solid var(--border);color:var(--muted);
  font-size:.78rem;padding:5px 14px;border-radius:999px}
.tag-cap:hover{color:#fff;background:var(--accent);border-color:var(--accent);text-decoration:none}
/* 女優枠(ジャンルタグと分離・暗めの赤で区別) */
.actress-box{display:flex;flex-wrap:wrap;align-items:center;gap:8px;margin:18px 0 0}
.actress-box-label{font-size:.78rem;font-weight:800;color:#a8164a}
.actress-cap{display:inline-block;background:color-mix(in srgb,#7d0f33 22%,var(--surface));
  border:1px solid #7d0f33;color:var(--text);font-size:.82rem;font-weight:700;
  padding:4px 14px;border-radius:999px;text-decoration:none}
.actress-cap:hover{background:#a8164a;border-color:#a8164a;color:#fff;text-decoration:none}
.actress-cloud a{border-color:#7d0f33;color:var(--text)}
.actress-cloud a:hover{background:#a8164a;border-color:#a8164a;color:#fff}
.pub-date{margin:0;color:var(--muted);font-size:.78rem}
.home-ad{display:flex;flex-direction:column;align-items:center;gap:14px;margin:34px 0;text-align:center}
.home-ad iframe{max-width:100%;border:0}
.home-ad .dmm-widget-placement{display:block;margin:0 auto;max-width:100%}
/* 元ツイートへのリンク(タグの上・目立つピル・Xロゴ付き) */
.x-post-link{display:inline-flex;align-items:center;gap:9px;margin:2px 0 0;padding:10px 20px;
  background:#fff;color:#000;border-radius:9999px;font-weight:800;font-size:1rem;
  text-decoration:none;border:1px solid #000;transition:transform .12s,box-shadow .12s}
.x-post-link:hover{transform:translateY(-1px);box-shadow:0 6px 18px rgba(255,255,255,.18);text-decoration:none}
.x-icon{width:20px;height:20px;flex:0 0 auto;color:#000}
/* recommendations carousel */
.reco{margin-top:36px}
.carousel{display:flex;gap:14px;overflow-x:auto;padding:6px 2px 12px;scroll-snap-type:x mandatory}
.carousel::-webkit-scrollbar{height:6px}
.carousel::-webkit-scrollbar-thumb{background:var(--border);border-radius:999px}
.reco-card{flex:0 0 220px;scroll-snap-align:start;background:var(--surface);border:1px solid var(--border);
  border-radius:12px;overflow:hidden}
.reco-card:hover{text-decoration:none;border-color:var(--accent)}
.reco-card .thumb{aspect-ratio:16/10;background:#000 center/cover no-repeat}
.reco-body{padding:10px 12px}
.reco-title{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
  color:var(--text);font-size:.85rem;line-height:1.4}
.reco-desc{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
  color:var(--muted);font-size:.76rem;line-height:1.45;margin-top:5px}
.section-title{font-family:var(--font-display);font-weight:700;font-size:1.25rem;margin:28px 0 4px;border-left:4px solid var(--accent);padding-left:10px}
.related{border-top:1px solid var(--border);margin-top:40px;padding-top:8px}
.cat-links a{display:inline-block;margin:0 8px 8px 0;background:var(--surface);border:1px solid var(--border);
  padding:6px 14px;border-radius:999px;font-size:.85rem;color:var(--muted)}
.cat-links a:hover{color:var(--text)}
.site-footer{border-top:1px solid var(--border);color:var(--muted);font-size:.82rem;padding:24px 0 48px;text-align:center}
.site-footer a{color:var(--muted)}
.powered-by{display:inline-flex;align-items:center;gap:5px;margin-top:4px;font-size:.76rem;
  color:var(--muted);opacity:.75;letter-spacing:.02em}
.powered-by:hover{opacity:1;color:var(--text);text-decoration:none}
.powered-by strong{font-weight:700;color:var(--text)}
/* サイドバーの自作FC2ランキングバナー(サイトデザイン一致・規約準拠のテキストリンク) */
.rank-vote{display:flex;flex-direction:column;align-items:center;gap:3px;margin:0 0 20px;padding:14px 12px;
  border-radius:12px;background:linear-gradient(135deg,var(--accent),#a8164a);
  border:1px solid var(--accent);text-decoration:none;text-align:center;
  box-shadow:0 4px 16px rgba(209,20,80,.25);transition:transform .12s,box-shadow .12s}
.rank-vote:hover{text-decoration:none;transform:translateY(-1px);box-shadow:0 6px 20px rgba(209,20,80,.38)}
.rank-vote-rank{font-size:.6rem;font-weight:800;letter-spacing:.2em;color:rgba(255,255,255,.85)}
.rank-vote-main{font-size:.9rem;font-weight:800;color:#fff}

/* ===== ranking (research: ファーストビューに番号付きランキング) ===== */
.ranking{display:grid;grid-template-columns:repeat(auto-fill,minmax(330px,1fr));gap:14px;padding:6px 0 16px}
.rank-card{display:flex;align-items:center;gap:12px;background:var(--surface);border:1px solid var(--border);
  border-radius:12px;padding:10px;position:relative;overflow:hidden}
.rank-card:hover{text-decoration:none;border-color:var(--accent)}
.rank-no{flex-shrink:0;width:30px;height:30px;display:flex;align-items:center;justify-content:center;
  border-radius:50%;font-weight:800;font-size:.95rem;background:var(--border);color:var(--text)}
.rank-1{background:linear-gradient(135deg,#f6d365,#e8a200);color:#241a00}
.rank-2{background:linear-gradient(135deg,#e2e8ee,#9aa6b2);color:#1a1f25}
.rank-3{background:linear-gradient(135deg,#e6a878,#c47b3f);color:#241200}
.rank-card .thumb{width:96px;height:60px;flex-shrink:0;border-radius:8px;background:#000 center/cover no-repeat}
.rank-body{display:flex;flex-direction:column;min-width:0}
.rank-title{color:var(--text);font-size:.9rem;line-height:1.35;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.rank-actress{color:var(--accent);font-size:.74rem;margin-top:3px}
/* ===== reco carousel thumb 16:9 ===== */
.reco-card .thumb{aspect-ratio:16/9}
/* ===== sticky CTA (research: 追従CTAで取りこぼし防止) ===== */
.sticky-cta{position:fixed;left:0;right:0;bottom:0;z-index:50;display:flex;justify-content:center;
  padding:10px 16px env(safe-area-inset-bottom,10px);
  background:color-mix(in srgb,var(--bg) 86%,transparent);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-top:1px solid var(--border)}
.sticky-cta a{display:block;max-width:520px;width:100%;text-align:center;background:var(--accent);color:#fff;
  font-weight:800;padding:14px;border-radius:999px;font-size:1rem;box-shadow:0 6px 20px rgba(209,20,80,.35)}
.sticky-cta a:hover{text-decoration:none;opacity:.93}
body{padding-bottom:84px}

/* ===== video preview card (X風リンクプレビュー: 画像+▶ → 商品ページ) ===== */
/* 記事の横幅いっぱい(本文と同幅)で目立たせる */
.video-card{display:block;width:100%;margin:22px 0;border:1px solid var(--border);border-radius:14px;
  overflow:hidden;background:var(--surface);box-shadow:0 8px 24px rgba(0,0,0,.25)}
.video-card:hover{text-decoration:none;border-color:var(--accent)}
.video-thumb{display:block;position:relative;aspect-ratio:16/9;background:#000 center/cover no-repeat}
.video-thumb .play{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:72px;height:72px;border-radius:50%;background:rgba(209,20,80,.92);color:#fff;
  display:flex;align-items:center;justify-content:center;font-size:1.8rem;padding-left:6px;
  box-shadow:0 4px 16px rgba(0,0,0,.4);transition:transform .15s}
.video-card:hover .play{transform:translate(-50%,-50%) scale(1.1)}
.video-label{display:block;text-align:center;background:var(--accent);color:#fff;font-weight:800;
  padding:13px;font-size:1.05rem}
/* FANZA: 画像を加工せずプレーン表示し下にボタン(▶オーバーレイなし) */
.prod-image{display:block;width:100%;margin:22px 0 0;border-radius:12px;overflow:hidden;border:1px solid var(--border)}
.prod-image img{display:block;width:100%;height:auto}
.prod-btn{display:block;text-align:center;background:var(--accent);color:#fff;font-weight:800;
  padding:13px;font-size:1.05rem;border-radius:10px;margin:10px 0 22px}
.prod-btn:hover{text-decoration:none;opacity:.92}
/* ソクミル API 利用規約のクレジットバナー(記事内) */
.sokmil-credit{margin:6px 0 20px;text-align:right}
.sokmil-credit img{display:inline-block;opacity:.85}
/* FANZA litevideo iframe(インライン再生)＋play-fakeフォールバック(遮断時) */
/* 幅は litevideo プレイヤーのネイティブ720pxに上限(中央寄せ)。box がプレイヤーより広いと
   左右余白に iframe 背面の cover 画像が透けてはみ出すため、box=プレイヤー幅に揃える。 */
/* カバー画像は常に背景(center/cover)。プレイヤー(iframe/video)が読めれば背面を覆い、
   広告ブロッカーが遮断/除去してもこの背景カバーが残る(onload/onerror 非依存の安全網) */
.video-embed{position:relative;width:100%;max-width:720px;margin:22px auto;aspect-ratio:720/480;
  border-radius:12px;overflow:hidden;background:#000 center/cover no-repeat;border:1px solid var(--border)}
.video-embed iframe{position:absolute;inset:0;width:100%;height:100%;border:0;z-index:1}
.fanza-embed{background:#000 center/cover no-repeat}
/* SOKMIL の onerror フォールバック(cover画像+▶→商品ページ)。SOKMIL以外では使わない。 */
.video-fallback{position:absolute;inset:0;z-index:2;background:#000 center/cover no-repeat;
  display:flex;align-items:center;justify-content:center}
.video-fallback .play{width:72px;height:72px;border-radius:50%;background:rgba(209,20,80,.92);color:#fff;
  display:flex;align-items:center;justify-content:center;font-size:1.8rem;padding-left:6px;
  box-shadow:0 4px 16px rgba(0,0,0,.4)}
/* SOKMIL: 自前プロキシ経由の <video> をインライン再生。読めない時のみ .novideo で
   フォールバック(cover画像+▶→商品ページ)へ切替える(MGS/FANZAと逆で初期は動画を表示)。 */
.sokmil-embed .sokmil-video{position:absolute;inset:0;width:100%;height:100%;z-index:1;
  background:#000;object-fit:contain}
.sokmil-embed .video-fallback{display:none}
.sokmil-embed.novideo .sokmil-video{display:none}
.sokmil-embed.novideo .video-fallback{display:flex}
/* MGS/FANZA の no-iframe レイヤー: <video>(inline-video)を主に表示。読めない時のみ .novideo で
   フォールバック(JS が退避 iframe=旧方針を挿入、または cover画像+▶→商品ページ)へ切替える。
   挿入された iframe は ▶カード(z-index:2)より前面(z-index:3)にして再生を優先する。 */
.video-embed .inline-video{position:absolute;inset:0;width:100%;height:100%;z-index:1;
  background:#000;object-fit:contain}
.video-embed .video-fallback{display:none}
.video-embed.novideo .inline-video{display:none}
.video-embed.novideo .video-fallback{display:flex}
.video-embed.novideo iframe{z-index:3}

/* ===== 時限属性の動的マーカー(本文/タイトルに焼かず、その時の状態として表示) ===== */
.status-markers{display:flex;flex-wrap:wrap;gap:8px;margin:14px 0 0}
/* 表示中マーカーが1つも無ければ畳む(余白を残さない)。子spanはhiddenでも残るため :empty では不可。 */
.status-markers:not(:has(.status-marker:not([hidden]))){display:none}
.status-marker{display:inline-flex;align-items:center;gap:4px;font-size:.72rem;font-weight:800;
  letter-spacing:.04em;padding:4px 11px;border-radius:999px;line-height:1.4}
.status-marker[hidden]{display:none}
.status-marker.is-new{background:var(--accent);color:#fff}
.status-marker.is-popular{background:var(--gold);color:#1a1a1a}
/* ===== a11y: 本文へスキップリンク(キーボード時のみ可視) ===== */
.skip-link{position:absolute;left:8px;top:-44px;z-index:200;background:var(--accent);color:#fff;
  padding:8px 14px;border-radius:0 0 8px 8px;font-weight:700;transition:top .15s}
.skip-link:focus{top:0;text-decoration:none}
/* ===== a11y: 可視キーボードフォーカス(hover だけに頼らない) ===== */
a:focus-visible,button:focus-visible,[tabindex]:focus-visible{
  outline:3px solid var(--accent);outline-offset:2px;border-radius:6px}
/* ===== a11y: モーション削減の尊重 ===== */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;
    transition-duration:.001ms!important;scroll-behavior:auto!important}
  .card:hover,.feature-card:hover,.hero-card:hover,.reco-card:hover,
  .x-post-link:hover,.rank-vote:hover,.hero-card:hover .hero-play{transform:none}
}
