/* =========================================================================
   DokoMiru デザイン探索プロトタイプ 共通CSS（proto.css）
   本番 style.css には一切手を入れない独立ファイル。6プロトを名前空間で分離:
   detail: .da-(A 洗練) .db-(B 配信主役) .dc-(C 没入)
   top:    .ta-(A 検索中心) .tb-(B ファセット) .tc-(C ディスカバリー)
   ========================================================================= */
:root{
  --pp-bg:#0f1014; --pp-bg2:#15171d; --pp-card:#1b1e26; --pp-line:#2a2e3a;
  --pp-text:#eef0f4; --pp-mut:#9aa3b2; --pp-mut2:#6b7280;
  --pp-gold:#f5c518; --pp-acc:#3b82f6; --pp-flat:#22c55e; --pp-rent:#f59e0b;
  --pp-radius:14px; --pp-shadow:0 8px 30px rgba(0,0,0,.35);
}
.proto-banner{position:sticky;top:0;z-index:50;display:flex;gap:12px;align-items:center;
  padding:8px 16px;font-size:13px;font-weight:600;color:#0f1014;
  background:linear-gradient(90deg,var(--pp-gold),#ffd966);box-shadow:0 2px 12px rgba(0,0,0,.3)}
.proto-banner .pb-tag{background:#0f1014;color:var(--pp-gold);padding:2px 9px;border-radius:999px;font-size:12px}
.proto-banner .pb-links{margin-left:auto;display:flex;gap:8px;flex-wrap:wrap}
.proto-banner .pb-links a{color:#0f1014;text-decoration:underline;opacity:.8}
.proto-banner .pb-links a:hover{opacity:1}
.pp-wrap{max-width:1080px;margin:0 auto;padding:20px 16px 60px}
.pp-chip{display:inline-flex;align-items:center;gap:6px;padding:7px 13px;border-radius:999px;
  background:var(--pp-card);border:1px solid var(--pp-line);color:var(--pp-text);
  font-size:13px;text-decoration:none;transition:.15s;white-space:nowrap}
.pp-chip:hover{border-color:var(--pp-gold);transform:translateY(-1px)}
.pp-chip .n{color:var(--pp-mut2);font-size:11px}
.pp-sec-h{font-size:15px;font-weight:700;color:var(--pp-mut);margin:26px 0 12px;letter-spacing:.04em}

/* ===== 共通：作品カード（プロト用・横スクロール棚で使用） ===== */
.pp-rail{display:flex;gap:12px;overflow-x:auto;padding:4px 2px 14px;scroll-snap-type:x mandatory}
.pp-rail::-webkit-scrollbar{height:8px}.pp-rail::-webkit-scrollbar-thumb{background:var(--pp-line);border-radius:4px}
/* 横スクロール行「右にまだある」キュー: 右端フェード（視覚）＋右送りボタン（三角・タップで1作品分スクロール）。
   cue-more（overflow有＆末尾未到達）の時だけ表示。ボタンは右端を覆い、一番右の作品リンクを踏まずにスクロールする。 */
.pp-rail-wrap{position:relative}
.pp-rail-wrap::after{content:"";position:absolute;top:0;bottom:14px;right:0;width:64px;
  pointer-events:none;opacity:0;transition:opacity .2s;
  background:linear-gradient(90deg,transparent,var(--pp-bg) 78%)}
.pp-rail-wrap.cue-more::after{opacity:.95}
.pp-rail-next{position:absolute;top:0;bottom:14px;right:0;width:64px;border:0;
  background:linear-gradient(90deg,transparent,rgba(0,0,0,.4) 52%);  /* タップ範囲が分かる薄い黒 */
  cursor:pointer;display:none;align-items:center;justify-content:flex-end;padding:0 8px 0 0;z-index:3}
.pp-rail-wrap.cue-more .pp-rail-next{display:flex}
.pp-rail-next .tri{width:32px;height:32px;border-radius:50%;background:rgba(255,255,255,.95);
  display:flex;align-items:center;justify-content:center;box-shadow:0 2px 10px rgba(0,0,0,.55);transition:transform .12s}
.pp-rail-next:hover .tri,.pp-rail-next:active .tri{transform:scale(1.08)}
.pp-rail-next .tri::before{content:"";border-style:solid;border-width:7px 0 7px 12px;
  border-color:transparent transparent transparent #0f1014;margin-left:3px}
.pp-card{flex:0 0 132px;scroll-snap-align:start;text-decoration:none;color:var(--pp-text)}
.pp-card img,.pp-card .noimg{width:132px;height:198px;object-fit:cover;border-radius:10px;
  background:var(--pp-bg2);display:block}
.pp-card .noimg{display:flex;align-items:center;justify-content:center;text-align:center;
  font-size:12px;color:var(--pp-mut);padding:8px}
.pp-card .ct{font-size:12.5px;margin-top:6px;line-height:1.35;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.pp-card .cb{display:flex;gap:3px;margin-top:4px;flex-wrap:wrap}
.pp-badge{font-size:9px;padding:1px 5px;border-radius:4px;color:#fff;font-weight:700}
.pp-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(132px,1fr));gap:14px}

/* offerボタン共通 */
.pp-offer{display:flex;flex-direction:column;gap:1px;padding:11px 14px;border-radius:11px;
  text-decoration:none;color:#fff;font-weight:700;font-size:14px;position:relative;
  border-left:5px solid rgba(255,255,255,.55);transition:.15s}
.pp-offer:hover{filter:brightness(1.12);transform:translateY(-1px)}
.pp-offer small{font-weight:500;font-size:11px;opacity:.92}
.pp-offer .ends{color:#fff;background:rgba(0,0,0,.25);padding:1px 6px;border-radius:5px;font-size:10px}

/* =========================================================================
   詳細A：現DokoMiru改善・洗練エディトリアル（読みやすさ重視・配信ファースト）
   ========================================================================= */
.da{max-width:920px;margin:0 auto;padding:18px 16px 70px;color:var(--pp-text)}
.da-fact{font-size:15px;line-height:1.7;background:var(--pp-bg2);border:1px solid var(--pp-line);
  border-left:4px solid var(--pp-gold);border-radius:10px;padding:13px 16px;margin:6px 0 18px}
.da-head{display:flex;gap:20px}
.da-poster{flex:0 0 150px}.da-poster img{width:150px;border-radius:12px;box-shadow:var(--pp-shadow)}
.da-h1{font-size:25px;font-weight:800;line-height:1.25;margin:0 0 8px}
.da-meta{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:10px}
.da-tag{font-size:12px;padding:3px 9px;border-radius:7px;background:var(--pp-card);border:1px solid var(--pp-line);color:var(--pp-mut)}
.da-tag.season a{color:var(--pp-gold);text-decoration:none}
.da-likes{color:#fb7185;font-weight:700}
.da-ratings{display:flex;gap:14px;flex-wrap:wrap;margin:4px 0 6px}
.da-rate{display:flex;flex-direction:column;line-height:1.1}
.da-rate b{font-size:18px}.da-rate span{font-size:10px;color:var(--pp-mut2)}
.da-prov-h{font-size:13px;color:var(--pp-mut);font-weight:700;margin:14px 0 8px;display:flex;gap:8px;align-items:center}
.da-prov-h::after{content:"";flex:1;height:1px;background:var(--pp-line)}
.da-offers{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:9px;margin-bottom:8px}
.da-upcoming{background:linear-gradient(90deg,rgba(59,130,246,.15),transparent);border:1px solid rgba(59,130,246,.4);
  border-radius:10px;padding:10px 14px;margin:10px 0;font-size:14px}
.da-upcoming b{color:#93c5fd}
.da-desc{font-size:15px;line-height:1.85;margin:16px 0;color:#d7dbe2}
.da-staff p{font-size:14px;line-height:1.7;margin:3px 0;color:var(--pp-mut)}
.da-staff .lb{display:inline-block;width:64px;color:var(--pp-mut2);font-size:12px}
.da-staff a{color:#cdd3dc;text-decoration:none;border-bottom:1px dotted var(--pp-mut2)}
.da-origin{display:flex;gap:10px;flex-wrap:wrap;margin:10px 0}
.da-origin a,.da-origin span{font-size:13px;background:var(--pp-card);border:1px solid var(--pp-line);
  padding:6px 12px;border-radius:8px;color:var(--pp-text);text-decoration:none}
.da-origin a:hover{border-color:var(--pp-gold)}
.da-tags{display:flex;gap:6px;flex-wrap:wrap;margin:8px 0}
.da-tags a{font-size:12px;color:var(--pp-mut);background:var(--pp-bg2);padding:4px 10px;border-radius:999px;text-decoration:none}

/* =========================================================================
   詳細B：配信サービス主役型（どこで見れるが主役・価格比較・高コントラスト）
   ========================================================================= */
.db{max-width:1000px;margin:0 auto;padding:18px 16px 70px;color:var(--pp-text)}
.db-hero{display:grid;grid-template-columns:1fr;gap:14px;background:var(--pp-bg2);
  border:1px solid var(--pp-line);border-radius:18px;padding:20px;margin-bottom:14px}
.db-htop{display:flex;gap:16px;align-items:flex-start}
.db-htop img{width:96px;border-radius:10px;flex:0 0 96px}
.db-h1{font-size:23px;font-weight:800;margin:0 0 6px;line-height:1.25}
.db-fact{font-size:14px;line-height:1.6;color:#cbd2dc}
.db-watch-h{font-size:13px;letter-spacing:.1em;color:var(--pp-gold);font-weight:800;margin:2px 0 2px}
.db-svc{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:10px}
.db-svc-card{display:flex;align-items:center;gap:12px;padding:13px 15px;border-radius:13px;
  text-decoration:none;color:#fff;font-weight:700;position:relative;overflow:hidden;min-height:58px}
.db-svc-card::before{content:"";position:absolute;inset:0;background:rgba(0,0,0,.18)}
.db-svc-card>*{position:relative;z-index:1}
.db-svc-card .nm{font-size:15px}.db-svc-card .meta{font-size:11px;opacity:.9;font-weight:500;display:block;margin-top:2px}
.db-svc-card .price{margin-left:auto;text-align:right;font-size:15px}
.db-svc-card .price small{display:block;font-size:10px;opacity:.85;font-weight:500}
.db-flag{display:inline-block;font-size:10px;font-weight:800;padding:2px 7px;border-radius:5px;margin-bottom:6px}
.db-flag.flat{background:var(--pp-flat);color:#04220f}.db-flag.rent{background:var(--pp-rent);color:#2a1800}
.db-section{background:var(--pp-bg2);border:1px solid var(--pp-line);border-radius:14px;padding:16px 18px;margin:12px 0}
.db-section h2{font-size:16px;margin:0 0 10px}
.db-metarow{display:flex;flex-wrap:wrap;gap:8px;margin:10px 0}
.db-metarow .m{font-size:12px;background:var(--pp-card);border:1px solid var(--pp-line);padding:4px 10px;border-radius:7px;color:var(--pp-mut)}
.db-rate-row{display:flex;gap:18px;flex-wrap:wrap}
.db-rate-row .r b{font-size:20px;color:var(--pp-gold)}.db-rate-row .r span{font-size:11px;color:var(--pp-mut2);display:block}
.db-desc{font-size:14.5px;line-height:1.8;color:#d3d8e0}
.db-staff{font-size:13.5px;line-height:1.7;color:var(--pp-mut)}
.db-staff a{color:#cdd3dc;text-decoration:none;border-bottom:1px dotted var(--pp-mut2)}
.db-staff .lb{color:var(--pp-mut2);width:58px;display:inline-block}

/* =========================================================================
   詳細C：リッチ没入型（フルブリードbackdrop・予告編主役・シネマティック）
   ========================================================================= */
.dc{color:var(--pp-text)}
.dc-hero{position:relative;min-height:430px;display:flex;align-items:flex-end;
  padding:30px 16px 22px;overflow:hidden}
/* 背景フォールバック3段: backdrop有=鮮明 / backdrop無posterあり=.posterでぼかし / 両方無=このグラデ */
.dc-hero-bg{position:absolute;inset:0;background-size:cover;background-position:center top;filter:saturate(1.05);
  background-color:#15171d;background-image:linear-gradient(135deg,#242a3a 0%,#15171d 60%,#0f1014 100%)}
.dc-hero-bg.poster{filter:blur(24px) saturate(1.35);transform:scale(1.14)}
.dc-hero-bg::after{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(15,16,20,.35)0%,rgba(15,16,20,.82)68%,var(--pp-bg)100%)}
.dc-hero-in{position:relative;z-index:2;max-width:1000px;margin:0 auto;width:100%;display:flex;gap:24px;align-items:flex-end}
.dc-hero-in img.pst{width:170px;border-radius:14px;box-shadow:0 14px 50px rgba(0,0,0,.6);flex:0 0 170px}
.dc-h1{font-size:38px;font-weight:900;line-height:1.1;margin:0 0 10px;text-shadow:0 2px 20px rgba(0,0,0,.5)}
.dc-fact{font-size:15px;line-height:1.6;max-width:640px;color:#e4e8ef;margin-bottom:0}
.dc-metab{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:12px}
.dc-metab .m{font-size:12px;background:rgba(255,255,255,.1);backdrop-filter:blur(6px);
  padding:4px 11px;border-radius:999px;border:1px solid rgba(255,255,255,.16)}
.dc-metab .m.score{color:var(--pp-gold);font-weight:700}
.dc-cta{display:flex;gap:10px;flex-wrap:wrap}
.dc-cta a{padding:11px 20px;border-radius:11px;font-weight:800;text-decoration:none;font-size:14px}
.dc-cta .play{background:var(--pp-gold);color:#0f1014}
.dc-cta .ghost{background:rgba(255,255,255,.12);color:#fff;border:1px solid rgba(255,255,255,.25)}
.dc-body{max-width:1000px;margin:0 auto;padding:6px 16px 70px}
.dc-trailer{margin:22px 0 10px}
.dc-trailer iframe{width:100%;aspect-ratio:16/9;border:0;border-radius:16px;box-shadow:var(--pp-shadow)}
/* clips 2本以上の「予告編・PV」サムネ行（クリックでメインiframeに差し替え）。横スクロールで全デバイス対応 */
.dc-clip-h{font-size:13px;font-weight:700;color:var(--pp-mut);margin:6px 0 8px}
.dc-clip-row{display:flex;gap:10px;overflow-x:auto;padding-bottom:6px;scroll-snap-type:x mandatory;margin-bottom:8px}
.dc-clip-row::-webkit-scrollbar{height:6px}
.dc-clip-row::-webkit-scrollbar-thumb{background:var(--pp-line);border-radius:3px}
.dc-clip{flex:0 0 160px;scroll-snap-align:start;background:none;border:0;padding:0;cursor:pointer;
  text-align:left;color:var(--pp-text);position:relative;font:inherit}
.dc-clip img{width:160px;height:90px;object-fit:cover;border-radius:8px;display:block;
  border:2px solid transparent;background:var(--pp-bg2);transition:border-color .15s}
.dc-clip::before{content:"▶";position:absolute;top:32px;left:0;right:0;text-align:center;
  color:rgba(255,255,255,.92);font-size:15px;text-shadow:0 1px 5px rgba(0,0,0,.85);pointer-events:none}
.dc-clip:hover img,.dc-clip.on img{border-color:var(--pp-gold)}
.dc-clip-cap{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
  font-size:11px;color:var(--pp-mut);margin-top:4px;line-height:1.3;width:160px}
@media(max-width:640px){.dc-clip{flex:0 0 140px}.dc-clip img{width:140px;height:79px}.dc-clip-cap{width:140px}.dc-clip::before{top:26px}}
/* 配信サービス一覧の均等折返し（.dc-watch はCプロト専用クラス＝他プロト不変）。
   列数はテンプレ側でorphan回避のバランス値 .dc-cols-N (cap4) を算出付与。狭幅は2列に落とす。
   等幅セルでもボタン内テキストが折返せるよう pp-offer に min-width:0（C限定スコープ）。 */
.dc-watch{display:grid;gap:10px;margin:8px 0;grid-template-columns:repeat(2,minmax(0,1fr))}
.dc-watch.dc-cols-1{grid-template-columns:minmax(180px,280px)}  /* 1件は引き伸ばさず自然幅(左寄せ) */
.dc-watch.dc-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}
.dc-watch.dc-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}
.dc-watch.dc-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}
.dc-watch .pp-offer{min-width:0;overflow-wrap:anywhere}
@media(max-width:600px){.dc-watch.dc-cols-3,.dc-watch.dc-cols-4{grid-template-columns:repeat(2,minmax(0,1fr))}}
.dc-grad-h{font-size:19px;font-weight:800;margin:26px 0 12px;
  background:linear-gradient(90deg,var(--pp-gold),#fff);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;display:inline-block}
.dc-desc{font-size:16px;line-height:1.9;color:#dde2ea;max-width:760px}
.dc-cols{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:18px}
/* スタッフ欄: ラベル列を固定幅・値は値カラム内で折返し（声優等の長い値が左ラベル下に食い込まない） */
.dc-staff p{font-size:14px;margin:5px 0;color:var(--pp-mut);display:flex;gap:10px;align-items:baseline}
.dc-staff a{color:#dfe4ec;text-decoration:none;border-bottom:1px dotted var(--pp-mut2)}
.dc-staff .lb{flex:0 0 56px;width:56px;color:var(--pp-mut2);font-size:12px}
.dc-staff .val{flex:1 1 auto;min-width:0;line-height:1.85;word-break:break-word}
.dc-backs{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:8px}
.dc-backs img{width:100%;border-radius:10px;display:block}
/* 場面写真の均等折返し（C限定）: 広=4列1行 / 中=2+2 / 狭=2列。3+1の不均等を回避。
   `.dc` 直下のみ＝他プロト(a/b/d)の .dc-backs は完全に不変。最大4枚なので割り切れる列数だけ使う。
   高さ不揃いによるガタつき防止に画像を16:9で揃える（こちらもC限定）。 */
.dc .dc-backs{grid-template-columns:repeat(4,1fr)}
.dc .dc-backs img{aspect-ratio:16/9;object-fit:cover}
@media(max-width:900px){.dc .dc-backs{grid-template-columns:repeat(2,1fr)}}
/* スマホ修正: ヒーローを1カラム縦積み（ポスター上→情報全幅）。背景は全幅のまま没入感維持。
   メタはflex-wrapで横並び折り返し、事実文は全幅で潰れない。 */
@media(max-width:640px){
  .dc-hero{min-height:320px;padding:22px 14px 18px;align-items:flex-end}
  .dc-hero-in{flex-direction:column;align-items:flex-start;gap:13px}
  .dc-hero-in img.pst{width:100px;flex:none;box-shadow:0 8px 26px rgba(0,0,0,.55)}
  .dc-h1{font-size:24px;line-height:1.2}
  .dc-fact{max-width:none;font-size:14px}
  .dc-metab{gap:6px}
  .dc-cta{width:100%}
  .dc-cta a{flex:1;text-align:center}
  .dc-cols{grid-template-columns:1fr;gap:18px}
  .dc-grad-h{font-size:17px}
  .dc-desc{font-size:15px}
  .dc-body{padding:6px 14px 60px}
}

/* 共通：詳細フッターの関連棚・FAQ */
.pp-related{max-width:1000px;margin:0 auto;padding:0 16px}
.pp-related .h{display:flex;align-items:baseline;gap:10px;margin:22px 0 8px}
.pp-related .h a{font-size:12px;color:var(--pp-gold);text-decoration:none}
.pp-faq{background:var(--pp-bg2);border:1px solid var(--pp-line);border-radius:14px;padding:16px 18px;margin:18px 0}
.pp-faq dt{font-weight:700;margin-top:10px}.pp-faq dd{color:var(--pp-mut);margin:4px 0 0;line-height:1.6}
.pp-upd{color:var(--pp-mut2);font-size:12px;margin-top:14px}

/* =========================================================================
   TOP A：検索バー中心型（巨大検索＋全次元チップが下に放射）
   ========================================================================= */
.ta{max-width:880px;margin:0 auto;padding:40px 16px 70px;text-align:center}
.ta-kicker{color:var(--pp-gold);font-weight:700;letter-spacing:.1em;font-size:13px}
.ta-h1{font-size:34px;font-weight:900;margin:8px 0 6px;line-height:1.2}
.ta-sub{color:var(--pp-mut);font-size:15px;margin-bottom:24px}
.ta-search{display:flex;gap:0;max-width:600px;margin:0 auto 8px;box-shadow:var(--pp-shadow);border-radius:14px;overflow:hidden}
.ta-search input{flex:1;border:0;padding:18px 20px;font-size:17px;background:#fff;color:#111}
.ta-search button{border:0;padding:0 26px;background:var(--pp-gold);color:#0f1014;font-weight:800;font-size:16px;cursor:pointer}
.ta-hint{color:var(--pp-mut2);font-size:12px;margin-bottom:30px}
.ta-block{text-align:left;margin:22px 0}
.ta-block h3{font-size:13px;color:var(--pp-mut);letter-spacing:.06em;margin:0 0 10px;display:flex;align-items:center;gap:8px}
.ta-block h3 .ic{font-size:16px}
.ta-chips{display:flex;flex-wrap:wrap;gap:8px;justify-content:flex-start}
.ta-cols{display:grid;grid-template-columns:1fr 1fr;gap:20px}
@media(max-width:640px){.ta-cols{grid-template-columns:1fr}.ta-h1{font-size:26px}}
.ta-strip{margin-top:30px}

/* =========================================================================
   TOP B：ファセット中心型（左に多次元フィルタ・右に結果グリッド＝DB探索）
   ========================================================================= */
.tb{max-width:1180px;margin:0 auto;padding:18px 16px 60px;display:grid;grid-template-columns:268px 1fr;gap:22px}
@media(max-width:820px){.tb{grid-template-columns:1fr}}
.tb-rail{background:var(--pp-bg2);border:1px solid var(--pp-line);border-radius:14px;padding:14px;align-self:start;position:sticky;top:12px}
.tb-rail h2{font-size:14px;margin:0 0 4px}.tb-rail .sub{font-size:11px;color:var(--pp-mut2);margin-bottom:10px}
.tb-facet{border-top:1px solid var(--pp-line);padding:11px 0}
.tb-facet>summary{cursor:pointer;font-size:13px;font-weight:700;color:var(--pp-text);list-style:none;display:flex;justify-content:space-between}
.tb-facet>summary::after{content:"＋";color:var(--pp-mut2)}.tb-facet[open]>summary::after{content:"－"}
.tb-facet .opts{display:flex;flex-wrap:wrap;gap:6px;margin-top:9px}
.tb-facet .opts a{font-size:12px;padding:5px 9px;border-radius:7px;background:var(--pp-card);border:1px solid var(--pp-line);color:var(--pp-text);text-decoration:none}
.tb-facet .opts a:hover{border-color:var(--pp-acc)}
.tb-facet .opts label{font-size:12px;display:flex;gap:5px;align-items:center;color:var(--pp-mut);width:100%}
.tb-main h1{font-size:20px;margin:0 0 2px}
.tb-main .cnt{color:var(--pp-mut);font-size:13px;margin-bottom:14px}
.tb-applied{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:12px}
.tb-applied .pill{font-size:11px;background:rgba(59,130,246,.18);border:1px solid rgba(59,130,246,.5);color:#bfdbfe;padding:3px 10px;border-radius:999px}

/* =========================================================================
   TOP C：ディスカバリーハブ型（リッチな棚を縦に・データの豊かさを一望）
   ========================================================================= */
.tc-hero{background:radial-gradient(1200px 400px at 50% -120px,rgba(245,197,24,.16),transparent),var(--pp-bg2);
  border-bottom:1px solid var(--pp-line);padding:34px 16px 26px;text-align:center}
.tc-hero h1{font-size:30px;font-weight:900;margin:0 0 6px}
.tc-hero p{color:var(--pp-mut);font-size:15px;margin:0 0 16px}
.tc-stats{display:flex;gap:24px;justify-content:center;flex-wrap:wrap}
.tc-stats .s b{font-size:24px;color:var(--pp-gold);display:block}
.tc-stats .s span{font-size:11px;color:var(--pp-mut2)}
.tc-quick{display:flex;gap:8px;justify-content:center;flex-wrap:wrap;margin-top:16px}
.tc-body{max-width:1180px;margin:0 auto;padding:10px 16px 70px}
.tc-shelf{margin:26px 0}
.tc-shelf .sh{display:flex;align-items:baseline;gap:12px;margin-bottom:10px}
.tc-shelf .sh h2{font-size:18px;margin:0}.tc-shelf .sh a{font-size:12px;color:var(--pp-gold);text-decoration:none;margin-left:auto}
.tc-axis{margin:30px 0}
.tc-axis h2{font-size:15px;color:var(--pp-mut);letter-spacing:.05em;margin:0 0 12px}
.tc-axis-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:10px}
.tc-axis-card{background:var(--pp-card);border:1px solid var(--pp-line);border-radius:12px;padding:14px 16px;
  text-decoration:none;color:var(--pp-text);transition:.15s;display:block}
.tc-axis-card:hover{border-color:var(--pp-gold);transform:translateY(-2px)}
.tc-axis-card b{font-size:15px}.tc-axis-card span{font-size:11px;color:var(--pp-mut2);display:block;margin-top:3px}
.tc-svc-strip{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:10px}
.tc-svc{display:flex;align-items:center;justify-content:center;height:54px;border-radius:12px;color:#fff;
  font-weight:800;text-decoration:none;font-size:14px;position:relative}
.tc-svc::after{content:"";position:absolute;inset:0;background:rgba(0,0,0,.12);border-radius:12px}
.tc-svc span{position:relative;z-index:1}

/* =========================================================================
   詳細D（ボーナス）：データ比較・意思決定ツール型（配信を表で一覧・素早く決める）
   ========================================================================= */
.dd{max-width:960px;margin:0 auto;padding:18px 16px 70px;color:var(--pp-text)}
.dd-top{display:flex;gap:16px;align-items:flex-start;margin-bottom:14px}
.dd-top img{width:88px;border-radius:10px;flex:0 0 88px}
.dd-h1{font-size:22px;font-weight:800;margin:0 0 4px;line-height:1.25}
.dd-fact{font-size:13.5px;line-height:1.6;color:#cbd2dc;margin:6px 0}
.dd-dash{display:flex;gap:10px;flex-wrap:wrap;margin-top:8px}
.dd-kpi{background:var(--pp-card);border:1px solid var(--pp-line);border-radius:10px;padding:8px 13px;text-align:center;min-width:74px}
.dd-kpi b{font-size:18px;display:block;color:var(--pp-gold)}.dd-kpi span{font-size:10px;color:var(--pp-mut2)}
.dd-tbl-h{font-size:13px;font-weight:800;letter-spacing:.08em;color:var(--pp-gold);margin:6px 0 8px}
.dd-table{width:100%;border-collapse:collapse;font-size:13.5px;background:var(--pp-bg2);border-radius:12px;overflow:hidden}
.dd-table th{text-align:left;font-size:11px;color:var(--pp-mut2);font-weight:700;padding:9px 12px;border-bottom:1px solid var(--pp-line);background:#13151b}
.dd-table td{padding:10px 12px;border-bottom:1px solid var(--pp-line);vertical-align:middle}
.dd-table tr:last-child td{border-bottom:0}
.dd-svc-pill{display:inline-flex;align-items:center;gap:7px;font-weight:700}
.dd-svc-pill .dot{width:10px;height:10px;border-radius:3px}
.dd-form{font-size:10px;font-weight:800;padding:2px 7px;border-radius:5px}
.dd-form.flat{background:var(--pp-flat);color:#04220f}.dd-form.rent{background:var(--pp-rent);color:#2a1800}.dd-form.buy{background:#a855f7;color:#fff}
.dd-go{display:inline-block;background:var(--pp-gold);color:#0f1014;font-weight:800;font-size:12px;padding:6px 14px;border-radius:8px;text-decoration:none}
.dd-go:hover{filter:brightness(1.08)}
.dd-cols{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin:18px 0}
@media(max-width:680px){.dd-cols{grid-template-columns:1fr}.dd-table{font-size:12px}.dd-table th,.dd-table td{padding:7px 8px}}
.dd-box{background:var(--pp-bg2);border:1px solid var(--pp-line);border-radius:12px;padding:14px 16px}
.dd-box h3{font-size:13px;color:var(--pp-mut);margin:0 0 8px}
.dd-box p{font-size:13.5px;line-height:1.7;margin:3px 0;color:var(--pp-mut)}
.dd-box a{color:#cdd3dc;text-decoration:none;border-bottom:1px dotted var(--pp-mut2)}
.dd-box .lb{width:56px;display:inline-block;color:var(--pp-mut2);font-size:12px}

/* =========================================================================
   TOP D（ボーナス）：気分・邦洋韓インテント型（大タブ＋今夜の1本＋気分チップ）
   ========================================================================= */
.td-hero{padding:30px 16px 10px;text-align:center}
.td-hero h1{font-size:28px;font-weight:900;margin:0 0 18px}
.td-tabs{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;max-width:760px;margin:0 auto}
@media(max-width:560px){.td-tabs{grid-template-columns:repeat(2,1fr)}}
.td-tab{display:flex;flex-direction:column;align-items:center;gap:6px;padding:20px 10px;border-radius:16px;
  text-decoration:none;color:#fff;font-weight:800;font-size:16px;position:relative;overflow:hidden}
.td-tab::after{content:"";position:absolute;inset:0;background:rgba(0,0,0,.16)}
.td-tab span{position:relative;z-index:1}.td-tab .em{font-size:30px}
.td-body{max-width:1080px;margin:0 auto;padding:14px 16px 70px}
.td-tonight{display:flex;gap:18px;align-items:center;background:radial-gradient(600px 200px at 0% 0%,rgba(245,197,24,.14),transparent),var(--pp-bg2);
  border:1px solid var(--pp-line);border-radius:18px;padding:18px;margin:24px 0}
.td-tonight img{width:120px;border-radius:12px;flex:0 0 120px;box-shadow:var(--pp-shadow)}
.td-tonight .lab{color:var(--pp-gold);font-weight:800;font-size:12px;letter-spacing:.1em}
.td-tonight h2{font-size:22px;margin:6px 0}
.td-tonight p{color:var(--pp-mut);font-size:13.5px;line-height:1.6;margin:0 0 10px;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.td-mood h3{font-size:14px;color:var(--pp-mut);margin:24px 0 10px}
