﻿@charset "UTF-8";

/* =========================
Variables / Base
========================= */
:root{
  --panel:#ffffff;
  --text:#1a1a1a;
  --muted:#666;
  --accent:#2563eb;
  --border:#e6e6eb;
  --ring:rgba(37,99,235,.35);
  --radius:12px;
}

/* 追加：幅計算の事故防止（このCSS内だけで完結） */
*, *::before, *::after{
  box-sizing:border-box;
}

/* 追加：HTML4.01 doctype + HTML5要素混在対策（CSSが効かないと崩れやすいので保険） */
header, section, nav, main, article, aside, footer{
  display:block;
}

html, body{
  height:100%;
}

body{
  margin:0;
  font-family:system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,"Apple Color Emoji","Segoe UI Emoji";
  color:var(--text);
  background:var(--bg);
  line-height:1.65;
}

/* 追加：画像が親幅を突き抜ける事故防止 */
img{
  max-width:100%;
  height:auto;
}

/* =========================
Optional: iframe / mobile header/footer
========================= */
.site-iframe{
  display:block;
  margin-left:auto;
  margin-right:auto;
}

/* モバイル専用ヘッダ/フッタはデフォルト非表示 */
.mobile-header,
.mobile-footer{
  display:none;
}

/* モバイルヘッダ画像の調整 */
.mobile-header{
  max-width:980px;
  margin:0 auto;
  padding:12px 20px 0;
}

.mobile-header img{
  display:block;
  max-width:240px;
  width:100%;
  height:auto;
  margin:12px auto;
}

/* モバイルフッタの調整 */
.mobile-footer{
  max-width:980px;
  margin:0 auto;
  padding:16px 20px 32px;
  text-align:center;
  color:var(--muted);
  font-size:12px;
}

/* =========================
Layout
========================= */
.container{
  max-width:980px;
  margin-inline:auto;
  padding:24px 20px 64px;
}

/*
  flow-root で float を内包し、position を静的に戻す。
*/
.product-area{
  margin-bottom:12px;
  display:flow-root;   /* float潰れ対策 */
  position:static;     /* header に absolute/fixed が当たった時の保険 */
}

h1{
  font-size:clamp(22px, 3.2vw, 28px);
  margin:0 0 6px;
  letter-spacing:.01em;
}

.subtitle{
  color:var(--muted);
  margin:0 0 12px;
  font-size:14px;
}

/* =========================
Panel / Definition
========================= */
.panel{
  background:var(--panel);
  border:1px solid var(--border);
  border-radius:var(--radius);
  box-shadow:0 1px 0 rgba(0,0,0,.02);
}

.def{
  padding:18px 18px 6px;
}

.def h2{
  font-size:16px;
  margin:0 0 8px;
}

dl{
  display:grid;
  grid-template-columns:160px 1fr;
  gap:8px 16px;
  margin:0;
  padding:0;
  font-size:14px;
}

dt{
  font-weight:600;
}

dd{
  margin:0;
}

.muted{
  color:var(--muted);
}

/* =========================
Tools / Buttons
========================= */
.tools{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  align-items:center;
  padding:12px;
  border-top:1px solid var(--border);
  background:linear-gradient(#fff, #fdfdff);
  border-bottom-left-radius:var(--radius);
  border-bottom-right-radius:var(--radius);
}

.btn{
  appearance:none;
  border:1px solid var(--border);
  background:#fff;
  color:#111;
  padding:9px 12px;
  border-radius:10px;
  font-size:14px;
  cursor:pointer;
  transition:background .15s, border-color .15s, box-shadow .15s;
}

.btn:hover{
  background:#fafafa;
}

.btn:focus-visible{
  outline:none;
  border-color:var(--accent);
  box-shadow:0 0 0 4px var(--ring);
}

.count{
  font-size:12px;
  color:var(--muted);
  margin-left:auto;
  padding:0 6px;
}



/* =========================
FAQ (details/summary)
========================= */
.faq{
  margin-top:16px;
}

details.faq-item{
  background:var(--panel);
  border:1px solid var(--border);
  border-radius:12px;
  overflow:hidden;
}

details.faq-item + details.faq-item{
  margin-top:12px;
}

summary{
  list-style:none;
  cursor:pointer;
  padding:16px 48px 16px 16px;
  position:relative;
  font-weight:600;
  outline:none;
}

summary::-webkit-details-marker{
  display:none;
}

.caret{
  position:absolute;
  right:12px;
  top:16px;
  width:24px;
  height:24px;
  display:grid;
  place-items:center;
  color:var(--muted);
  transition:transform .2s ease;
}

details[open] .caret{
  transform:rotate(180deg);
}

.answer{
  padding:0 16px 16px 16px;
  border-top:1px solid var(--border);
  background:linear-gradient(#fff, #fcfcfe);
}

.answer p{
  margin:12px 0;
}

/* =========================
Product grid (image + link)
========================= */
.product-grid{
  display:grid;
  gap:16px;
  grid-template-columns:repeat(auto-fill, minmax(220px, 1fr));
  align-items:start;
  margin:12px 0 0;
}

.product-item{
  background:var(--panel);
  border:1px solid var(--border);
  border-radius:12px;
  padding:12px;
  text-align:center;
}

.product-thumb{
  display:block;
}

.product-thumb img{
  display:block;
  max-width:100%;
  height:auto;
  border-radius:8px;
  box-shadow:0 1px 0 rgba(0,0,0,.02);
}

.product-actions{
  margin-top:10px;
}

/* HTMLに product-link-btn があるので最低限の見た目を付ける */
.product-link-btn{
  display:inline-block;
  text-decoration:none;
  background:var(--accent);
  color:#fff;
  padding:10px 12px;
  border-radius:10px;
  font-size:14px;
  line-height:1.2;
}

.product-link-btn:focus-visible{
  outline:none;
  box-shadow:0 0 0 4px var(--ring);
}

/* 既存CSSの a指定（:link/:visited/:hover等）に負けないように強めに上書き */
.container .product-actions a.product-link-btn,
.container .product-actions a.product-link-btn:link,
.container .product-actions a.product-link-btn:visited,
.container .product-actions a.product-link-btn:hover,
.container .product-actions a.product-link-btn:active{
  background: #2563eb !important; /* 青背景 */
  color: #fff !important;        /* 白文字 */
  text-decoration: none !important;

  display: inline-block;
  padding: 10px 12px;
  border-radius: 10px;
  line-height: 1.2;
  border: 1px solid #2563eb;
}

/* =========================
Responsive (Mobile)
========================= */
@media (max-width:640px){
  /* iframeを隠し、代替ヘッダ/フッタを表示 */
  .site-iframe{ display:none; }
  .mobile-header,
  .mobile-footer{ display:block; }

  dl{ grid-template-columns:1fr; }
  dt{ color:var(--muted); }

  /* スマホは2列固定 */
  .product-grid{
    grid-template-columns:repeat(2, 1fr);
    gap:12px;
  }
}