/* camera-souba.com 個別 + hub 共通 CSS
   Phase 2 §5.3 (2026-06-17): build.py の inline <style> から外部化 (= 124 page 重複解消)
   ?v=YYYYMMDD クエリで cache-busting (= build.py: SITE_CSS_VERSION 定数)
   個別ページ default (.wrap=760px / h1=22px) は hub 側で inline override される
   .badge.mk は dynamic mk_color のため inline で個別注入される (= site.css には含めない)
*/

*{box-sizing:border-box}
body{margin:0;font-family:system-ui,-apple-system,"Hiragino Sans",sans-serif;background:#0f1115;color:#e5e7eb;line-height:1.7}
.wrap{max-width:760px;margin:0 auto;padding:24px 16px 80px}
.crumb{font-size:13px;color:#9ca3af;margin-bottom:16px}
.crumb a{color:#9ca3af;text-decoration:none}
.crumb a:hover{color:#e5e7eb}
h1{font-size:22px;margin:0 0 8px;line-height:1.4}

/* badges (= 個別 + hub 共通だが mk は inline 動的) */
.badges{display:flex;gap:8px;margin-bottom:16px;flex-wrap:wrap}
.badge{padding:3px 10px;border-radius:4px;font-size:12px;color:#fff;font-weight:600}
.badge.ty{background:#374151}
.badge.band{background:#1f2937;border:1px solid #374151;color:#e5e7eb}

/* 個別ページ専用 */
.updated{font-size:13px;color:#9ca3af;margin-bottom:24px}
.price-block{background:#1a1d24;border:1px solid #2a2e36;border-radius:8px;padding:14px 16px;margin-bottom:10px;display:block}
.price-block .k{font-size:13px;color:#9ca3af;margin-bottom:6px}
.price-val{font-size:22px;font-weight:700;color:#e5e7eb;word-break:break-word;line-height:1.4}
.price-val.muted{color:#6b7280;font-size:16px;font-weight:500}
.section{margin:28px 0}
.section h2{font-size:16px;margin:0 0 12px;padding-bottom:8px;border-bottom:1px solid #2a2e36}
.store-list{margin:0;padding:0 0 0 20px;color:#d1d5db;font-size:14px}
.store-list li{margin-bottom:4px}
.cta-row{display:flex;gap:8px;flex-wrap:wrap;margin-top:12px}
.cta{display:inline-flex;align-items:center;gap:6px;padding:12px 16px;border-radius:6px;text-decoration:none;font-weight:600;font-size:14px;flex:1 1 220px;justify-content:center}
.cta-komehyo{background:#d4a017;color:#000}
.cta-kitamura{background:#dc2626;color:#fff}
.cta-kitamura-shop{background:#1f2937;border:1px solid #dc2626;color:#fca5a5}
.cta-yahoo{background:#1f2937;border:1px solid #6b7280;color:#e5e7eb}
.cta-netoff{background:#0f9b8e;color:#fff}
.cta-rakuten{background:#bf0000;color:#fff}
.cta-pending{background:#1a1d24;border:1px dashed #4b5563;color:#9ca3af;cursor:default}
.pr-mark{font-size:11px;color:#6b7280;margin-top:10px}
.note{font-size:13px;color:#9ca3af;background:#1a1d24;border-left:3px solid #374151;padding:10px 12px;margin:14px 0;border-radius:0 4px 4px 0}
.related-list{margin:0;padding:0 0 0 20px;color:#d1d5db;font-size:14px}
.related-list li{margin-bottom:6px}
.related-list a{color:#fca5a5;text-decoration:none}
.related-list a:hover{color:#fff;text-decoration:underline}
.spec-table{width:100%;border-collapse:collapse;margin:8px 0 12px;font-size:14px}
.spec-table td{padding:8px 12px;border-bottom:1px solid #2a2e36}
.spec-table td:first-child{font-weight:600;color:#9ca3af;width:35%}
.spec-table td:last-child{color:#e5e7eb}
.spec-h3{font-size:15px;margin:18px 0 8px;color:#e5e7eb}
.spec-source{font-size:12px;color:#6b7280;margin:0 0 12px;word-break:break-all}
.spec-source a{color:#6b7280;text-decoration:underline}
.memo{font-size:14px;color:#d1d5db;background:#1a1d24;border-left:3px solid #6b7280;padding:10px 12px;border-radius:0 4px 4px 0;margin:0}
.hero-image{margin:16px 0 20px}
.hero-image img{width:100%;max-width:480px;height:auto;display:block;border-radius:6px;background:#1a1d24}
.image-credit{font-size:11px;color:#6b7280;margin:6px 0 0;word-break:break-all}
.image-credit a{color:#6b7280;text-decoration:underline}
.hub-link-row{display:flex;gap:10px;flex-wrap:wrap;margin-top:24px}
.hub-link{display:inline-block;padding:8px 14px;background:#1f2937;color:#9ec5fe;border-radius:6px;text-decoration:none;font-size:13.5px}
.hub-link:hover{background:#374151}
.howto-list{list-style:none;padding:0;margin:8px 0 0;counter-reset:howto-step}
.howto-step{background:#1a1d24;border:1px solid #2a2e36;border-radius:6px;padding:14px 16px;margin-bottom:10px}
.howto-step-h3{font-size:14px;margin:0 0 6px;color:#9ec5fe;letter-spacing:.02em}
.howto-step-text{font-size:13.5px;margin:0;color:#d1d5db;line-height:1.75}

/* hub ページ専用 (hub では inline で .wrap{max-width:960px} h1{font-size:24px;margin:0 0 24px} を override) */
.hub-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px}
.hub-card{background:#1a1d24;border:1px solid #2a2e36;border-radius:8px;padding:14px}
.hub-card__link{display:block;text-decoration:none;color:inherit}
.hub-card__link:hover .hub-card__title{color:#fca5a5}
.hub-card__title{font-size:15px;font-weight:600;margin-bottom:10px;line-height:1.4;color:#e5e7eb}
.hub-card__badges{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:12px}
.hub-card__row{display:flex;justify-content:space-between;font-size:13px;margin-bottom:4px}
.hub-card__row .k{color:#9ca3af}
.hub-card__row .v{color:#e5e7eb;font-weight:600}
.hub-siblings{margin-top:36px;padding:18px 0 6px;border-top:1px solid #2a2e36}
.hub-siblings h3{font-size:13px;color:#9ca3af;margin:0 0 10px;font-weight:600}
.hub-siblings + .hub-siblings{border-top:0;padding-top:6px;margin-top:14px}
.hub-siblings__list{display:flex;flex-wrap:wrap;gap:8px}
.hub-siblings__item{display:inline-block;padding:6px 10px;background:#1a1d24;border:1px solid #2a2e36;border-radius:6px;color:#9ec5fe;text-decoration:none;font-size:13px}
.hub-siblings__item:hover{background:#252932;color:#fff}
.hub-siblings__item.current{background:#2a2e36;color:#e5e7eb;border-color:#3a3f47;cursor:default}
.hub-siblings__count{color:#9ca3af;font-size:11.5px;margin-left:4px}

/* 共通: footer + back ボタン */
.back{display:inline-block;margin-top:32px;padding:9px 14px;background:#1f2937;color:#e5e7eb;border-radius:6px;text-decoration:none;font-size:14px}
.back:hover{background:#374151}
.page-footer{margin-top:40px;padding:20px 0 8px;border-top:1px solid #2a2e36;font-size:12.5px;color:#9ca3af;line-height:1.7}
.footer-links{margin-bottom:10px}
.footer-links a{color:#9ec5fe;text-decoration:none;margin-right:14px}
.footer-disclaimer{margin:0;font-size:11.5px;color:#6b7280}
.footer-disclaimer a{color:#9ec5fe;text-decoration:none}
