:root{
  --brand:#17a88e;
  --brand-ink:#0e6b5c;
  --bg:#f7faf9;
  --ink:#1f2937;
  --sub:#6b7280;
  --card:#ffffff;
  --border:#e5e7eb;
  --radius:16px;
  --shadow:0 6px 18px rgba(0,0,0,.06);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;color:var(--ink);background:var(--bg);font-family:Inter,"Noto Sans JP",system-ui,-apple-system,Segoe UI,Roboto,"Hiragino Kaku Gothic ProN","Yu Gothic",sans-serif;line-height:1.7}
a{color:var(--brand);text-decoration:none}
a:hover{opacity:.85}
.container{max-width:1140px;margin:0 auto;padding:0 16px}

.site-header{position:sticky;top:0;background:#fff;border-bottom:1px solid var(--border);z-index:10}
.site-header .container{display:flex;gap:24px;align-items:center;min-height:64px}
.brand{display:flex;align-items:baseline;gap:8px;color:var(--ink);font-weight:800}
.brand .logo{font-size:20px}
.brand .subtitle{color:var(--sub);font-size:12px}
.gnav__list{display:flex;gap:20px;list-style:none;margin:0;padding:0}
.gnav__list a{display:block;padding:10px 0;color:var(--ink)}
.site-main{padding-bottom:64px}
.site-footer{background:#0f172a;color:#cbd5e1;padding:40px 0}
.footer__grid{display:grid;grid-template-columns:1fr auto;gap:24px}
.footer__menu{display:flex;gap:16px;list-style:none;margin:0;padding:0}
.logo{font-weight:800;color:#fff}

.hero{background:linear-gradient(140deg,var(--brand),#14b8a6);color:#fff;padding:64px 0}
.hero h1{font-size:34px;margin:0 0 8px}
.lead{opacity:.9}

.block{padding:40px 0}
.block__head{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:16px}
.block__head h2{margin:0;font-size:22px}
.more{font-size:14px}

.grid{display:grid;gap:16px}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}
.grid-5{grid-template-columns:repeat(5,1fr)}
.grid-6{grid-template-columns:repeat(6,1fr)}
@media (max-width:960px){.grid-6,.grid-5,.grid-4,.grid-3{grid-template-columns:repeat(2,1fr)}}
@media (max-width:560px){.grid-6,.grid-5,.grid-4,.grid-3{grid-template-columns:1fr}}

.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}
.card img{display:block;width:100%;height:auto}
.card__body{padding:14px}
.card__title{margin:0 0 6px;font-size:18px;color:var(--ink)}
.card__meta{margin:0 0 8px;color:var(--sub);font-size:12px}
.card__excerpt{margin:0;color:var(--ink)}

.chip{display:inline-block;background:#e6fffa;border:1px solid #b2f5ea;color:var(--brand-ink);padding:6px 10px;border-radius:999px;font-size:12px}
.tag{display:inline-block;background:#eef2ff;color:#3730a3;padding:5px 8px;border-radius:8px;margin:4px 6px 0 0;font-size:12px}

.cta-split{background:#fff;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.cta-split__grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}
@media (max-width:960px){.cta-split__grid{grid-template-columns:1fr}}

.btn{display:inline-block;background:var(--brand);color:#fff;padding:10px 16px;border-radius:12px;border:1px solid var(--brand);box-shadow:var(--shadow)}
.btn:hover{filter:brightness(.98)}
.btn-lg{padding:14px 20px;font-weight:700}
.btn-outlined{background:#fff;color:var(--brand);border-color:var(--brand)}

.filter{background:#fff;border:1px solid var(--border);border-radius:12px;padding:16px;margin:16px 0}
.filter__row{display:flex;gap:12px;flex-wrap:wrap;align-items:end}
.filter__select{min-width:160px}
.tiny{font-size:12px;color:var(--sub)}
.list-news{list-style:none;margin:0;padding:0}
.list-news li{border-bottom:1px solid var(--border);padding:10px 0}
.list-news .date{display:inline-block;width:92px;color:var(--sub)}

.single__head h1{margin:0 0 10px}
.single__thumb{border-radius:12px;box-shadow:var(--shadow);margin:6px 0 16px}
.chips{display:flex;gap:8px;flex-wrap:wrap}

.lp-hero{background:#fff;border-bottom:1px solid var(--border);padding:40px 0}
.lp-body{padding:32px 0}
.search{display:flex;gap:8px;margin:10px 0 24px}
.search input{flex:1;padding:10px;border-radius:10px;border:1px solid var(--border)}

#prefecture-list h2{margin:16px 0 8px;font-size:18px}
#prefecture-list .grid-6 .chip{text-align:center}
#audience-list .chip{text-align:center}

/* =========================================================
   以降：/prefecture と /media を「狭幅＆タイト」化する上書き
   ※ テンプレ修正不要。セクションIDにぶら下がる .container を後段で上書き
   ========================================================= */

/* 狭幅コンテナ（この2ページだけ .container を 1040px に） */
#prefecture-list .container,
#media-type-list .container{
  max-width:1040px;
}

/* セクション上下余白を圧縮（親セクション＆配下ブロック） */
#prefecture-list,
#media-type-list{ padding:32px 0 }
#prefecture-list .block,
#media-type-list .block{ padding:28px 0 }

/* グループ（小セクション）間の間延び解消 */
#prefecture-list .block + .block,
#media-type-list .block + .block{ margin-top:16px }

/* 見出しの余白・サイズ最適化 */
#prefecture-list h2,
#media-type-list h2{
  margin:10px 0 12px;
  font-size:clamp(18px,1.6vw,20px);
  font-weight:700;
}

/* グリッドを可変カラム化＆ギャップ縮小（この2ページ内のみ） */
#prefecture-list .grid-6,
#media-type-list .grid-6{
  grid-template-columns:repeat(auto-fit,minmax(160px,1fr));
  gap:12px 16px;
}

/* チップを軽やかに（この2ページ内は少し小ぶりに） */
#prefecture-list .chip,
#media-type-list .chip{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:34px;
  padding:6px 14px;
  border-radius:999px;
  background:#e9fbf7;
  border:1px solid #b9efe3;
  line-height:1.2;
  transition:background .15s ease,transform .05s ease,box-shadow .15s ease;
  white-space:nowrap;
}
#prefecture-list .chip:hover,
#media-type-list .chip:hover{
  background:#d9f7ef;
  box-shadow:0 1px 0 rgba(0,0,0,.04);
  transform:translateY(-1px);
}
#prefecture-list .chip:focus-visible,
#media-type-list .chip:focus-visible{
  outline:2px solid var(--brand);
  outline-offset:2px;
}

/* モバイルはさらに詰める */
@media (max-width:640px){
  #prefecture-list,
  #media-type-list{ padding:24px 0 }
  #prefecture-list .block,
  #media-type-list .block{ padding:22px 0 }
  #prefecture-list .grid-6,
  #media-type-list .grid-6{ gap:10px 12px }
  #prefecture-list .chip,
  #media-type-list .chip{ padding:6px 12px; min-height:32px }
}

/* ===== Prefecture / Media の block 余白を強制圧縮 ===== */
:is(#prefecture-list, #media-type-list) {
  padding: 20px 0 !important;             /* 親セクション自体も圧縮 */
}

/* グループ見出しごとの <section class="block"> を詰める */
:is(#prefecture-list, #media-type-list) section.block {
  padding: 14px 0 !important;             /* 40px → 14px に */
  margin: 0 !important;
}

/* 連続する block の間もさらに詰める */
:is(#prefecture-list, #media-type-list) section.block + section.block {
  margin-top: 10px !important;
}

/* 見出し周りも少し締める */
:is(#prefecture-list, #media-type-list) h2 {
  margin: 8px 0 10px !important;
  font-size: clamp(18px, 1.6vw, 20px);
}

/* === Remove default block padding site-wide === */
.block {
  padding: 0 !important;
}

/* ====== ad_medium 個別ページ ====== */
.ad-detail .container{max-width:1040px;margin:0 auto;padding:0 16px}

/* 余白設計（全体タイト） */
.ad-hero{background:#fff;border-bottom:1px solid var(--border);padding:20px 0}
.ad-body{padding:20px 0}
.ad-detail .sec{padding:16px 0;border-top:1px solid var(--border)}
.ad-detail .sec:first-of-type{border-top:none}
.ad-detail .sec__title{margin:0 0 10px;font-size:18px;font-weight:700;display:flex;align-items:center;gap:8px}
.ad-detail .sec__title::before{content:"";width:4px;height:1.1em;background:#17a88e;border-radius:2px}

/* HERO head + aside 2col レイアウト */
.ad-hero__inner{display:grid;grid-template-columns:1fr 320px;gap:16px}
@media (max-width: 960px){.ad-hero__inner{grid-template-columns:1fr}}

.ad-breadcrumb{display:flex;gap:6px;color:var(--sub);font-size:12px;margin:0 0 6px}
.ad-title{margin:0 0 4px;font-size:24px;line-height:1.35}
.ad-catch{margin:0 0 10px;color:var(--brand-ink);font-weight:600}
.ad-tags{display:flex;gap:8px;flex-wrap:wrap}
.ad-hero__cta{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px}

/* 右サイド上部（HERO内カード） */
.ad-aside .ad-aside__card{position:sticky;top:76px;background:#fff;border:1px solid var(--border);border-radius:14px;padding:14px}
.ad-aside .aside-title{margin:0 0 8px;font-weight:700}
.ad-aside .btn-block{display:block;width:100%;text-align:center}
.ad-aside .aside-meta{list-style:none;margin:10px 0 0;padding:0;display:grid;gap:6px}
.ad-aside .aside-meta li{display:flex;justify-content:space-between;border:1px solid var(--border);border-radius:10px;padding:8px}
.ad-aside .aside-meta span{color:#64748b}
.ad-aside .aside-meta b{font-weight:700}

/* 本文2カラム（右レーンはSPで下に） */
.ad-grid{display:grid;grid-template-columns:minmax(0,1fr) 260px;gap:16px}
@media (max-width: 960px){.ad-grid{grid-template-columns:1fr}}
.ad-main{min-width:0}
.ad-side__sticky{position:sticky;top:84px;display:grid;gap:8px}

/* 注意書き */
.ad-note{background:#fff;border:1px solid var(--border);border-radius:12px;padding:10px;color:#475569;font-size:13px}

/* キー・バリューのグリッド */
.kv-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}
@media (max-width: 720px){.kv-grid{grid-template-columns:1fr}}
.kv-grid .kv{display:grid;grid-template-columns:160px 1fr;gap:8px;background:#fff;border:1px solid var(--border);border-radius:12px;padding:10px}
.kv-grid dt{color:#64748b}
.kv-grid dd{margin:0}

/* ポイント（番号ピル＋本文） */
.point-list{display:grid;gap:10px}
.point{display:grid;grid-template-columns:36px 1fr;gap:10px;background:#fff;border:1px solid var(--border);border-radius:12px;padding:10px}
.point__no{display:grid;place-items:center;background:#17a88e;color:#fff;width:36px;height:36px;border-radius:10px;font-weight:800}
.point__body h3{margin:0 0 6px;font-size:16px}
.point__body p{margin:0}

/* テーブル（コンパクト・横スクロール可） */
.tbl-wrap{background:#fff;border:1px solid var(--border);border-radius:12px;overflow:auto}
.tbl{width:100%;border-collapse:separate;border-spacing:0}
.tbl th,.tbl td{padding:10px 12px;border-bottom:1px solid var(--border);text-align:left;white-space:nowrap}
.tbl thead th{background:#f8fafc;color:#475569}
.tbl tr:last-child td{border-bottom:none}
.link-muted{margin-left:8px;font-size:12px;color:#475569}
.link-muted:hover{color:var(--brand)}

/* 手順（縦タイムライン） */
.steps{list-style:none;margin:0;padding:0;display:grid;gap:8px}
.steps li{position:relative;background:#fff;border:1px solid var(--border);border-radius:12px;padding:10px 12px 10px 38px}
.steps li::before{content:"";position:absolute;left:12px;top:50%;transform:translateY(-50%);width:14px;height:14px;border-radius:50%;background:#17a88e}
.steps li::after{content:"";position:absolute;left:18px;top:calc(50% + 14px);bottom:-8px;width:2px;background:#e5e7eb}
.steps li:last-child::after{display:none}

/* チップの見た目（控えめ） */
.ad-detail .chip{background:#e9fbf7;border:1px solid #b9efe3;color:var(--brand-ink);padding:4px 8px;border-radius:999px;font-size:12px}

/* 全体の余白をさらにタイトに（この詳細ページのみ） */
.ad-detail .block{padding:16px 0}