/* ============ GolfScale home (mock recreation) ============ */
/* 共有シェル(カラーパレット・ヘッダー・フッター)は gs-shell.css に集約。 */
.gs-home h2,.gs-home h3,.gs-home h4{ border-bottom:none; }

/* ---- hero ---- */
.gs-hero{ position:relative; overflow:hidden; background:rgb(253,250,243); }
.gs-hero-inner{ position:relative; min-height:444px; display:flex; align-items:flex-start; }
.gs-hero-text{ position:relative; z-index:2; width:49%; padding:40px 0 0; }
.gs-hero-photo{ position:absolute; z-index:1; top:8px; right:-150px; height:430px; width:auto; }
.gs-hero-h1{ font-size:3.5rem; font-weight:900; line-height:1.34; letter-spacing:.012em; color:var(--ink); margin:0 0 18px; }
.gs-hero-h1 em{ color:var(--g); font-style:normal; }
.gs-hero-lead{ font-size:1rem; line-height:1.95; color:#525d54; max-width:29em; margin:0 0 26px; }
.gs-stats{ display:flex; gap:30px; flex-wrap:wrap; }
.gs-stat{ display:flex; align-items:center; gap:11px; }
.gs-stat-ic{ width:40px; height:40px; border-radius:11px; background:var(--soft); border:1px solid var(--line);
  display:flex; align-items:center; justify-content:center; color:var(--g); flex-shrink:0; }
.gs-stat-ic .icon{ width:20px; height:20px; }
.gs-stat-label{ font-size:.72rem; color:#8a948c; font-weight:600; line-height:1.4; }
.gs-stat-num{ font-size:1.05rem; font-weight:800; color:var(--ink); line-height:1.3; }
.gs-stat-num small{ font-size:.72rem; font-weight:600; color:#8a948c; margin-left:3px; }

/* ---- search cards ---- */
.gs-cards-wrap{ margin-top:-52px; position:relative; z-index:5; }
.gs-cards{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
.gs-card{ background:#fff; border:1px solid var(--line); border-radius:18px; padding:22px 24px;
  display:flex; align-items:center; gap:14px; text-decoration:none;
  box-shadow:0 20px 34px -28px rgba(20,40,28,.55); transition:transform .18s ease, box-shadow .18s ease; }
.gs-card:hover{ transform:translateY(-4px); box-shadow:0 28px 44px -26px rgba(20,40,28,.5); }
.gs-card-ic{ width:62px; flex-shrink:0; display:flex; align-items:center; justify-content:center; color:var(--g); }
.gs-card-ic .icon{ width:52px; height:52px; }
.gs-card-body{ flex:1; min-width:0; }
.gs-card-body h3{ font-size:1.14rem; font-weight:800; color:var(--ink); margin:0 0 6px; }
.gs-card-body p{ font-size:.82rem; color:var(--mute); line-height:1.65; margin:0; }
.gs-card-go{ width:44px; height:44px; border-radius:50%; background:var(--g); color:#fff;
  display:flex; align-items:center; justify-content:center; flex-shrink:0; transition:transform .18s ease; }
.gs-card-go .icon{ width:20px; height:20px; }
.gs-card:hover .gs-card-go{ transform:translateX(3px); }

/* ---- section heading ---- */
.gs-sec-head{ display:flex; align-items:center; gap:9px; margin:50px 0 20px;
  padding-left:12px; border-left:3px solid currentColor; color:var(--g); }
.gs-sec-icon{ color:inherit; display:flex; }
.gs-sec-icon svg{ width:26px; height:26px; }
.gs-sec-icon.bar{ color:inherit; }
.gs-sec-icon.bar .icon{ width:23px; height:23px; }
/* セクションごとのアクセント色 (見出しアイコン + 左縦バー) */
.gs-sec-head.is-club{ color:#3f78bf; }
.gs-sec-head.is-shaft{ color:#c2792f; }
.gs-sec-head.is-ranking{ color:var(--y); }
.gs-sec-head.is-compare{ color:var(--g); }
.gs-sec-head.is-brand{ color:#8a5cb4; }
.gs-sec-head.is-matrix{ color:#4a8a8a; }
.gs-sec-title{ font-size:1.42rem; font-weight:800; color:var(--ink); margin:0; }
.gs-sec-more{ margin-left:auto; font-size:.85rem; font-weight:700; color:var(--g); text-decoration:none;
  display:inline-flex; align-items:center; gap:4px; }
.gs-sec-more:hover{ color:var(--g-dark); }
.gs-sec-more .icon{ width:14px; height:14px; }

/* ---- ranking ---- */
.gs-rank-row{ display:grid; grid-template-columns:repeat(5,1fr); gap:14px; }
.gs-rank-card{ position:relative; background:#fff; border:1px solid var(--line); border-radius:12px;
  padding:8px 11px 8px 9px; display:flex; align-items:center; gap:10px; text-decoration:none;
  box-shadow:0 12px 22px -24px rgba(20,40,28,.5); transition:transform .15s ease, box-shadow .15s ease; }
.gs-rank-card:hover{ transform:translateY(-2px); box-shadow:0 18px 28px -24px rgba(20,40,28,.45); }
.gs-rank-badge{ position:absolute; top:-8px; left:-8px; z-index:2;
  width:24px; height:24px; border-radius:50%; color:#fff;
  font-size:.74rem; font-weight:800; display:flex; align-items:center; justify-content:center;
  box-shadow:0 2px 6px rgba(20,40,28,.28); }
.gs-rank-badge.r1{ background:var(--y); color:#7a5a00; }
.gs-rank-badge.r2{ background:#c4cad0; color:#52585e; }
.gs-rank-badge.r3{ background:#d09a64; color:#fff; }
.gs-rank-badge.r4,.gs-rank-badge.r5{ background:var(--g); }
.gs-rank-thumb{ width:64px; height:64px; flex-shrink:0; object-fit:contain; }
.gs-rank-info{ min-width:0; flex:1; }
.gs-rank-brand{ display:block; font-size:.66rem; color:#8a948c; font-weight:700; }
.gs-rank-name{ display:block; font-size:.8rem; font-weight:700; color:var(--ink); line-height:1.3; margin:2px 0 3px;
  white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.gs-rank-rate{ display:flex; align-items:center; gap:4px; white-space:nowrap; }
.gs-rank-score{ font-size:.73rem; font-weight:800; color:var(--ink); }
.gs-rank-count{ font-size:.64rem; color:#8a948c; }

/* star rating */
.gs-stars{ display:inline-block; position:relative; font-size:.66rem; line-height:1;
  font-family:Arial,sans-serif; letter-spacing:.5px; }
.gs-stars::before{ content:"★★★★★"; color:#e0e5e0; }
.gs-stars::after{ content:"★★★★★"; color:var(--y); position:absolute; left:0; top:0;
  width:var(--p,90%); overflow:hidden; white-space:nowrap; }

/* ---- spec compare ---- */
.gs-spec-grid{ display:grid; grid-template-columns:1fr 286px; gap:18px; align-items:start; }
.gs-cmp-row{ display:grid; grid-template-columns:repeat(3,1fr); gap:14px; }
.gs-cmp-card{ background:#fff; border:1px solid var(--line); border-top-width:3px; border-radius:14px;
  padding:13px 14px; box-shadow:0 16px 28px -28px rgba(20,40,28,.5); color:var(--ink); }
.gs-cmp-slot1{ border-top-color:#2F8F5B; }
.gs-cmp-slot2{ border-top-color:#e0af28; }
.gs-cmp-slot3{ border-top-color:#3f78bf; }
.gs-cmp-card select{ width:100%; padding:6px 7px; border:1px solid var(--line); border-radius:7px;
  font-size:.73rem; font-weight:600; color:var(--ink); background:#fff; cursor:pointer; }
.gs-cmp-card select:focus{ outline:none; border-color:var(--g); box-shadow:0 0 0 3px rgba(47,143,91,.15); }
.gs-cmp-filters{ display:flex; gap:6px; margin-bottom:6px; }
.gs-cmp-filters select{ min-width:0; }
.gs-cmp-sel-club{ margin-bottom:11px; }
.gs-cmp-head{ display:flex; gap:11px; align-items:flex-start; }
.gs-cmp-thumb{ width:62px; height:62px; object-fit:contain; flex-shrink:0; }
.gs-cmp-titles{ flex:1; min-width:0; }
.gs-cmp-titlerow{ display:flex; align-items:flex-start; justify-content:space-between; gap:6px; }
.gs-cmp-brand{ font-size:.71rem; color:#8a948c; font-weight:700; }
.gs-cmp-name{ font-size:.92rem; font-weight:800; color:var(--ink); line-height:1.32; margin-top:2px;
  display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }
.gs-cmp-year{ flex-shrink:0; font-size:.6rem; font-weight:700; color:#7a857d;
  background:var(--bg); border-radius:7px; padding:3px 7px; white-space:nowrap; }
.gs-cmp-score{ display:flex; align-items:center; gap:6px; margin:12px 0 11px;
  border-top:1px solid var(--line); padding-top:11px; }
.gs-cmp-score-num{ font-size:.92rem; font-weight:800; color:var(--ink); }
.gs-cmp-score-cap{ font-size:.66rem; font-weight:700; color:#8a948c;
  background:var(--soft); border-radius:6px; padding:2px 7px; }
.gs-metric{ display:flex; align-items:center; gap:8px; margin-bottom:7px; }
.gs-metric-label{ font-size:.7rem; color:var(--mute); width:74px; flex-shrink:0; white-space:nowrap; }
.gs-bar{ flex:1; height:7px; border-radius:5px; background:#edf0ed; overflow:hidden; }
.gs-bar i{ display:block; height:100%; border-radius:5px;
  background:linear-gradient(90deg,#3a9d66,#2F8F5B); }
.gs-metric-val{ font-size:.75rem; font-weight:800; color:var(--ink); width:30px; text-align:right; flex-shrink:0; }

/* radar card */
.gs-radar-card{ background:#fff; border:1px solid var(--line); border-radius:16px; padding:16px 16px;
  display:flex; flex-direction:column; box-shadow:0 16px 28px -28px rgba(20,40,28,.5); }
.gs-radar-card h3{ font-size:.98rem; font-weight:800; color:var(--ink); margin:0 0 4px; text-align:center; }
.gs-radar-wrap{ flex:1; display:flex; align-items:center; justify-content:center; }
.gs-radar-wrap svg{ width:100%; max-width:248px; height:auto; }
.gs-radar-legend{ display:flex; justify-content:center; gap:14px; margin:4px 0 12px; flex-wrap:wrap; }
.gs-radar-legend span{ display:flex; align-items:center; gap:5px; font-size:.68rem; font-weight:700; color:var(--mute); }
.gs-radar-legend i{ width:16px; height:0; border-top:3px solid currentColor; display:inline-block; border-radius:2px; }
.gs-leg-1{ color:#2F8F5B; }
.gs-leg-2{ color:#e0af28; }
.gs-leg-3{ color:#3f78bf; }
.gs-rp-1{ fill:rgba(47,143,91,.18); stroke:#2F8F5B; stroke-width:2; }
.gs-rp-2{ fill:rgba(224,175,40,.20); stroke:#e0af28; stroke-width:2; }
.gs-rp-3{ fill:rgba(63,120,191,.16); stroke:#3f78bf; stroke-width:2; }
.gs-radar-btn{ display:flex; align-items:center; justify-content:center; gap:7px;
  border:1.5px solid var(--g); color:var(--g); background:#fff; border-radius:11px;
  padding:10px; font-size:.82rem; font-weight:700; text-decoration:none; transition:background .15s; }
.gs-radar-btn:hover{ background:var(--soft); color:var(--g); }
.gs-radar-btn .icon{ width:13px; height:13px; }

/* ---- latest (new arrivals) ---- */
.gs-latest-nav{ display:flex; gap:8px; margin-left:auto; }
.gs-latest-nav-btn{ width:34px; height:34px; border:1px solid var(--line); border-radius:50%;
  background:#fff; color:var(--ink); display:flex; align-items:center; justify-content:center;
  cursor:pointer; transition:background .15s, color .15s, border-color .15s, opacity .15s; }
.gs-latest-nav-btn:hover:not(:disabled){ background:var(--g); border-color:var(--g); color:#fff; }
.gs-latest-nav-btn:disabled{ opacity:.35; cursor:not-allowed; }
.gs-latest-nav-btn .icon{ width:15px; height:15px; }
.gs-latest-scroll{ display:grid; grid-auto-flow:column; grid-auto-columns:minmax(272px,272px);
  gap:14px; overflow-x:auto; scroll-snap-type:x mandatory; scroll-behavior:smooth;
  padding-bottom:6px; -ms-overflow-style:none; scrollbar-width:none; }
.gs-latest-scroll::-webkit-scrollbar{ display:none; }
.gs-latest-card{ display:flex; align-items:center; gap:11px; background:#fff; border:1px solid var(--line);
  border-radius:12px; padding:9px 11px; color:var(--ink); text-decoration:none; scroll-snap-align:start;
  box-shadow:0 12px 22px -24px rgba(20,40,28,.5);
  transition:transform .15s ease, box-shadow .15s ease, border-color .15s ease; }
.gs-latest-card:hover{ transform:translateY(-2px); box-shadow:0 18px 28px -24px rgba(20,40,28,.45); border-color:#cdddcf; }
.gs-latest-thumb{ width:60px; height:60px; flex-shrink:0; border-radius:9px;
  background:linear-gradient(135deg,#f6faf6,#eef4ee); display:flex; align-items:center;
  justify-content:center; overflow:hidden; }
.gs-latest-thumb img{ width:100%; height:100%; object-fit:contain; padding:4px; }
.gs-latest-ph{ color:#b4c2b6; display:flex; }
.gs-latest-ph .icon{ width:24px; height:24px; }
.gs-latest-info{ min-width:0; flex:1; }
.gs-latest-brand{ display:block; font-size:.72rem; color:#8a948c; font-weight:700; }
.gs-latest-title{ display:block; font-size:.88rem; font-weight:700; line-height:1.3; color:var(--ink);
  margin:1px 0 3px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.gs-latest-rate{ display:flex; align-items:center; gap:5px; white-space:nowrap; }
.gs-latest-attn{ font-size:.7rem; color:#8a948c; font-weight:700; }
.gs-latest-attn-val{ font-size:.84rem; font-weight:800; color:var(--ink); }
.gs-latest-date{ font-size:.78rem; color:#8a948c; font-variant-numeric:tabular-nums; }
.gs-latest-tag{ font-size:.68rem; font-weight:700; color:var(--g);
  background:var(--soft); border-radius:5px; padding:2px 7px; }
.gs-latest-rate .gs-stars{ font-size:.82rem; }

/* ---- brand grid (horizontal cards: logo left, name right) ---- */
.gs-brand-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:12px; }
.gs-brand-card{ background:#fff; border:1px solid var(--line); border-radius:14px;
  padding:11px 14px; text-decoration:none; color:var(--ink); display:flex; flex-direction:row;
  align-items:center; gap:12px; transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease; }
.gs-brand-card:hover{ transform:translateY(-3px); box-shadow:0 18px 30px -24px rgba(20,40,28,.4); border-color:#cdddcf; }
.gs-brand-logo{ width:48px; height:48px; border-radius:11px;
  display:flex; align-items:center; justify-content:center; overflow:hidden; flex:0 0 auto; }
.gs-brand-logo img{ max-width:38px; max-height:38px; object-fit:contain; }
.gs-brand-logo-fb{ font-size:1.2rem; font-weight:800; color:var(--g); }
.gs-brand-info{ min-width:0; display:flex; flex-direction:column; gap:2px; }
.gs-brand-name{ font-size:.9rem; font-weight:700; text-align:left; line-height:1.3;
  white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.gs-brand-count{ font-size:.72rem; font-weight:600; color:#8a948c; }

/* ---- tour explainer cards (hero thumb + horizontal scroll) ---- */
.gs-tour-actions{ display:flex; align-items:center; gap:14px; margin-left:auto; }
.gs-tour-actions .gs-latest-nav{ margin-left:0; }
.gs-tour-scroll{ grid-auto-columns:minmax(244px,244px); gap:12px; }
@media (max-width: 900px){ .gs-tour-scroll{ grid-auto-columns:minmax(220px,220px); } }
.gs-tour-card{ display:flex; flex-direction:column; background:#fff;
  border:1px solid var(--line); border-radius:14px; overflow:hidden;
  text-decoration:none; color:var(--ink); scroll-snap-align:start;
  box-shadow:0 12px 22px -24px rgba(20,40,28,.5);
  transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease; }
.gs-tour-card:hover{ transform:translateY(-3px);
  box-shadow:0 18px 30px -24px rgba(20,40,28,.4); border-color:#cdddcf; }
.gs-tour-thumb{ display:block; width:100%; aspect-ratio:16/9; overflow:hidden;
  background:linear-gradient(135deg,#f6faf6,#eef4ee); }
.gs-tour-thumb img{ width:100%; height:100%; object-fit:cover; display:block;
  transition:transform .3s ease; }
.gs-tour-card:hover .gs-tour-thumb img{ transform:scale(1.04); }
.gs-tour-thumb-ph{ width:100%; height:100%; display:flex; align-items:center;
  justify-content:center; color:#b6c4b8; }
.gs-tour-body{ display:flex; flex-direction:column; gap:.3rem;
  padding:.6rem .8rem .75rem; }
.gs-tour-title{ font-size:.9rem; font-weight:700; line-height:1.35; color:var(--ink); }
.gs-tour-summary{ font-size:.74rem; line-height:1.5; color:#6b756f;
  display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }

/* ---- latest series matrix ---- */
.gs-series-filters{ display:flex; gap:8px; margin-left:auto; margin-bottom:0; }
.gs-series-fbtn{ display:inline-flex; align-items:center; gap:7px; padding:8px 15px;
  background:#fff; border:1px solid var(--line); border-radius:999px; color:var(--ink);
  font-size:.82rem; font-weight:700; cursor:pointer; line-height:1.2; }
.gs-series-fbtn::after{ content:""; width:5px; height:5px; border-right:1.6px solid currentColor;
  border-bottom:1.6px solid currentColor; transform:rotate(45deg) translate(-1px,-2px); opacity:.55; }
.gs-series-fbtn:hover,.gs-series-fbtn[aria-expanded="true"]{ background:var(--soft); border-color:#cdddcf; }
.gs-series-filters .dropdown-menu{ display:none; border:1px solid var(--line); border-radius:14px; padding:10px 12px;
  box-shadow:0 22px 44px -24px rgba(20,40,28,.3); max-height:58vh; overflow-y:auto; min-width:13rem; }
.gs-series-filters .dropdown-menu.show{ display:block; }
.gs-series-filters .form-check{ display:flex; align-items:center; gap:8px; padding:5px 4px; margin:0; border-radius:8px; }
.gs-series-filters .form-check:hover{ background:var(--soft); }
.gs-series-filters .form-check-input{ width:1.05em; height:1.05em; margin:0; float:none; flex-shrink:0;
  border:1.5px solid #cdddcf; cursor:pointer; }
.gs-series-filters .form-check-input:checked{ background-color:var(--g); border-color:var(--g); }
.gs-series-filters .form-check-label{ font-size:.86rem; color:var(--ink); cursor:pointer; margin:0; }
.gs-series-card{ background:#fff; border:1px solid var(--line); border-radius:16px;
  padding:6px 10px; overflow-x:auto; }
.gs-series-table{ width:100%; border-collapse:separate; border-spacing:0; }
.gs-series-table th,.gs-series-table td{ padding:7px 8px; text-align:center; vertical-align:middle;
  border-bottom:1px solid #eef1ee; }
.gs-series-table thead th{ background:var(--soft); font-size:.8rem; font-weight:800; color:var(--ink); white-space:nowrap; }
.gs-series-table thead th:first-child{ text-align:left; font-size:.7rem; color:#8a948c; letter-spacing:.04em; font-weight:700; }
.gs-series-table tbody th{ font-size:.78rem; font-weight:800; color:var(--ink); white-space:nowrap; width:88px; }
.gs-series-table tbody th img{ display:block; max-height:28px; max-width:64px; width:auto; margin:0 auto 3px; opacity:.9; }
.gs-series-table tbody tr:last-child th,.gs-series-table tbody tr:last-child td{ border-bottom:none; }
.gs-series-table tbody tr:hover th,.gs-series-table tbody tr:hover td{ background:#faf9f4; }
.gs-series-table td{ width:166px; }
.gs-series-table td a{ display:flex; flex-direction:row; align-items:center; gap:9px;
  color:var(--ink); text-decoration:none; text-align:left; transition:color .15s ease; }
.gs-series-table td a:hover{ color:var(--g); }
.gs-series-table td a img{ width:54px; height:54px; flex-shrink:0; object-fit:contain; }
.gs-series-cell-text{ display:flex; flex-direction:column; min-width:0; gap:1px; }
.gs-series-name{ font-size:.81rem; font-weight:700; line-height:1.3; }
.gs-series-year{ font-size:.71rem; color:#8a948c; }
.gs-series-empty{ color:#c2ccc4; }

/* ---- みんなのクラブセッティング (カード本体は bag_card.css で共有) ---- */
.gs-bags-card{ margin-top:50px;
  background:#fff; border:1px solid var(--line); border-radius:18px;
  padding:22px 26px; box-shadow:0 20px 34px -30px rgba(20,40,28,.5); }
.gs-bags-head{ display:flex; align-items:center; gap:9px; margin:0 0 8px; }
.gs-bags-head-ic{ color:var(--g); display:flex; }
.gs-bags-head-ic .icon{ width:22px; height:22px; }
.gs-bags-title{ font-size:1.24rem; font-weight:800; color:var(--ink); margin:0; }
.gs-bags-lead{ font-size:.82rem; color:var(--mute); line-height:1.7; margin:0 0 16px; }
.gs-bags-actions{ display:flex; align-items:center; gap:9px; margin-left:auto; }
.gs-bags-more{ font-size:.82rem; font-weight:700;
  color:var(--g); text-decoration:none; white-space:nowrap; }
.gs-bags-more:hover{ text-decoration:underline; }
.gs-bags-nav{ display:flex; gap:6px; }

@media (max-width:600px){
  .gs-bags-card{ padding:18px 16px; border-radius:14px; }
  .gs-bags-head{ flex-wrap:wrap; row-gap:8px; }
  .gs-bags-title{ font-size:1.1rem; white-space:nowrap; }
  .gs-bags-actions{ flex-basis:100%; margin-left:0; justify-content:flex-end; }
}

.gs-home{ padding-bottom:8px; }

@media (max-width:992px){
  /* hero: 文字を画像に重ねる。文字側に薄いクリームのグラデを敷いて可読性確保 */
  .gs-hero-inner{ display:block; position:relative; min-height:330px; }
  .gs-hero-photo{ position:absolute; top:0; right:-70px; height:100%; width:auto; z-index:1; }
  .gs-hero-text{ position:relative; z-index:2; width:80%; padding:32px 0 28px;
    background:linear-gradient(95deg, rgb(253,250,243) 54%, rgba(253,250,243,.72) 74%, rgba(253,250,243,0) 100%); }
  .gs-hero-h1{ font-size:2.3rem; line-height:1.3; }
  .gs-hero-lead{ font-size:.92rem; line-height:1.8; max-width:24em; }
  .gs-stats{ gap:18px; }
  .gs-cards-wrap{ margin-top:20px; }
  .gs-cards{ grid-template-columns:1fr; }
  .gs-spec-grid{ grid-template-columns:1fr; }
  .gs-cmp-row{ grid-template-columns:1fr; }
  /* 名器度ランキング・ブランドは横スクロール（スマホで右にはみ出さない） */
  .gs-rank-row, .gs-brand-grid{ display:flex; gap:12px; overflow-x:auto;
    scroll-snap-type:x mandatory; -webkit-overflow-scrolling:touch; scrollbar-width:none;
    margin:0 -18px; padding:12px 18px 10px; }
  .gs-rank-row::-webkit-scrollbar, .gs-brand-grid::-webkit-scrollbar{ display:none; }
  .gs-rank-row > *, .gs-brand-grid > *{ flex:0 0 auto; scroll-snap-align:start; }
  .gs-rank-row > *{ width:282px; }
  .gs-brand-grid > *{ width:210px; }
}
@media (max-width:600px){
  /* hero: 画像全体を最上部に表示、見出しはバッジ上の余白に重ねる。リード文・統計は画像の下 */
  .gs-hero-inner{ display:flex; flex-direction:column; position:relative; min-height:0; }
  .gs-hero-photo{
    order:-1;
    position:static; top:auto; right:auto;
    width:100vw; max-width:none; height:auto; display:block;
    margin-left:calc(50% - 50vw + 11vw);
  }
  .gs-hero-h1{
    /* バッジ（画像の y41%付近〜）より上の余白に収め、被らない位置に */
    position:absolute; z-index:3; top:3vw; left:6vw; margin:0;
    font-size:clamp(1.05rem, 4.7vw, 1.35rem); line-height:1.3;
    text-shadow:0 0 4px rgb(253,250,243), 0 0 8px rgb(253,250,243),
                0 0 12px rgb(253,250,243), 0 0 16px rgb(253,250,243),
                0 0 20px rgb(253,250,243), 0 1px 2px rgb(253,250,243);
  }
  .gs-hero-text{ position:static; width:100%; padding:16px 0 2px; background:none; }
  .gs-hero-lead{ font-size:.86rem; line-height:1.75; max-width:none; margin:0 0 16px; }
  .gs-stats{ gap:16px; }
  /* 検索カード: スマホはコンパクトに */
  .gs-cards-wrap{ margin-top:16px; }
  .gs-cards{ gap:10px; }
  .gs-card{ padding:13px 15px; border-radius:14px; gap:12px; }
  .gs-card-ic{ width:42px; }
  .gs-card-ic .icon{ width:34px; height:34px; }
  .gs-card-body h3{ font-size:1.02rem; margin:0 0 3px; }
  .gs-card-body p{ font-size:.75rem; line-height:1.55; }
  .gs-card-go{ width:34px; height:34px; }
  .gs-card-go .icon{ width:16px; height:16px; }
  .gs-sec-title{ font-size:1.2rem; }
}
