:root{
  --akane:#1f6f78;
  --akane-soft:#2f8a92;
  --okoshi-accent:#1f6f78;
  --okoshi-accent-dark:#164e55;
  --okoshi-warm:#b46a2a;
  --okoshi-soft:#e9f2f1;
  --bg:#f4f1ea;
  --bg-soft:#fbf8f0;
}

.sister{background:var(--okoshi-accent-dark);}
.brand .mark{background:var(--okoshi-accent);}
.spotlight{border-top-color:var(--okoshi-accent);}
footer.site{border-top-color:var(--okoshi-accent);}
footer.site .cols{
  grid-template-columns:1fr;
  gap:18px;
  padding-top:32px;
}
footer.site .fcol{
  min-width:0;
}
footer.site .fcol a{
  overflow-wrap:anywhere;
}
footer.site .legal{
  gap:12px 18px;
}
footer.site .brandfoot{
  border-top:1px solid var(--border-soft);
  margin-top:0;
  padding-top:22px;
}
@media(min-width:560px){
  footer.site .cols{grid-template-columns:repeat(2,minmax(0,1fr));}
}
@media(min-width:900px){
  footer.site .cols{grid-template-columns:repeat(4,minmax(0,1fr));}
}

@media(max-width:899px){
  header.site{
    box-shadow:0 6px 18px rgba(31,28,20,.08);
  }
  header.site .row{
    height:auto;
    min-height:64px;
    flex-wrap:wrap;
    align-content:center;
    row-gap:8px;
    padding-top:9px;
    padding-bottom:9px;
  }
  .brand{
    min-width:0;
    flex:1 1 calc(100% - 56px);
  }
  .brand .name{
    display:block;
    max-width:calc(100vw - 118px);
    overflow:hidden;
    text-overflow:ellipsis;
    white-space:nowrap;
  }
  nav.main{
    order:3;
    display:flex;
    width:100%;
    gap:6px;
    overflow-x:auto;
    padding:2px 0 1px;
    scrollbar-width:none;
    -webkit-overflow-scrolling:touch;
  }
  nav.main::-webkit-scrollbar{display:none;}
  nav.main a{
    flex:0 0 auto;
    border:1px solid var(--border-soft);
    border-radius:var(--r-pill);
    background:var(--bg-soft);
    margin:0;
    padding:5px 10px;
    font-size:11px;
  }
  nav.main a.active{
    color:#fff;
    background:var(--okoshi-accent);
    border-color:var(--okoshi-accent);
  }
  .searchbtn{
    margin-left:auto;
  }
  .searchbtn{
    display:none;
  }
  .sister .wrap{
    justify-content:flex-start;
    overflow:hidden;
    white-space:nowrap;
  }
  .sister .wrap span:last-child{
    display:none;
  }
}

.hero-actions{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:8px;
  max-width:560px;
  margin-top:12px;
}
.hero-actions a{
  display:flex;
  flex-direction:column;
  gap:1px;
  min-width:0;
  border:1px solid var(--border);
  border-radius:10px;
  background:var(--paper);
  padding:10px 12px;
  color:inherit;
}
.hero-actions a:hover{
  border-color:var(--okoshi-accent);
  background:var(--okoshi-soft);
}
.hero-actions span{
  font-family:var(--serif);
  font-size:14px;
  font-weight:700;
  line-height:1.25;
}
.hero-actions b{
  font-family:var(--mono);
  font-size:9px;
  letter-spacing:.08em;
  color:var(--ink-3);
  text-transform:uppercase;
}

.deadline-box{
  margin-top:18px;
  border-top:1px solid var(--border-soft);
  padding-top:14px;
}
.deadline-label{
  font-family:var(--mono);
  font-size:10px;
  letter-spacing:.14em;
  color:var(--ink-3);
  text-transform:uppercase;
  margin-bottom:8px;
}
.deadline-item{
  display:flex;
  justify-content:space-between;
  gap:12px;
  padding:8px 0;
  border-bottom:1px solid var(--border-soft);
}
.deadline-item:last-child{border-bottom:0;}
.deadline-item strong{
  font-family:var(--serif);
  font-size:13px;
  line-height:1.35;
}
.deadline-item span{
  font-family:var(--mono);
  font-size:10px;
  color:var(--okoshi-warm);
  white-space:nowrap;
}

.recruitment-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:12px;
}
@media(min-width:760px){
  .recruitment-grid{grid-template-columns:repeat(2,1fr);}
}
.recruitment-card{
  background:var(--paper);
  border:1px solid var(--border);
  border-top:3px solid var(--okoshi-accent);
  border-radius:2px 2px var(--r-card) var(--r-card);
  padding:18px 20px;
  display:flex;
  flex-direction:column;
  min-width:0;
  min-height:260px;
}
.recruitment-card:hover{border-color:var(--okoshi-accent);}
.card-top{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:12px;
  min-width:0;
}
.recruitment-card h3{
  font-family:var(--serif);
  font-weight:600;
  font-size:19px;
  line-height:1.4;
  margin:8px 0 4px;
  overflow-wrap:anywhere;
}
.recruitment-card .place{
  font-family:var(--mono);
  font-size:10px;
  letter-spacing:.08em;
  color:var(--ink-3);
  text-transform:uppercase;
}
.summary{
  font-family:var(--sans);
  font-size:13px;
  color:var(--ink-2);
  line-height:1.75;
  margin:10px 0 0;
  overflow-wrap:anywhere;
}
.card-facts{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:8px;
  margin:14px 0;
}
.fact{
  background:var(--bg-soft);
  border:1px solid var(--border-soft);
  border-radius:8px;
  padding:8px 9px;
  min-width:0;
}
.fact span{
  display:block;
  font-family:var(--mono);
  font-size:9px;
  letter-spacing:.08em;
  color:var(--ink-3);
  text-transform:uppercase;
}
.fact strong{
  display:block;
  font-family:var(--sans);
  font-size:12px;
  color:var(--ink-2);
  margin-top:2px;
  overflow-wrap:anywhere;
}
.card-actions{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  margin-top:auto;
  padding-top:12px;
}
.textlink{
  font-family:var(--sans);
  font-size:12px;
  font-weight:700;
  color:var(--okoshi-accent);
  text-decoration:underline;
  text-underline-offset:3px;
}
.textlink.muted{
  color:var(--ink-3);
  text-decoration:none;
}
.buttonlink{
  font-family:var(--sans);
  font-size:12px;
  font-weight:700;
  color:#fff;
  background:var(--okoshi-accent);
  border-radius:var(--r-pill);
  padding:7px 12px;
}
.buttonlink:hover{background:var(--okoshi-accent-dark);}
.load-more{
  display:block;
  min-width:180px;
  margin:22px auto 0;
  border:1px solid var(--border-strong);
  background:var(--paper);
  color:var(--ink-2);
  border-radius:var(--r-pill);
  padding:10px 18px;
  font-family:var(--sans);
  font-size:13px;
  font-weight:800;
  cursor:pointer;
}
.load-more:hover{
  border-color:var(--okoshi-accent);
  color:var(--okoshi-accent);
}

.recruitment-filters{
  margin:0 0 14px;
  align-items:stretch;
}
.recruitment-filters .searchbox{
  flex:1 1 320px;
  max-width:480px;
  margin-top:0;
}
.recruitment-filters .sel{
  min-height:42px;
}
.filter-reset{
  min-height:42px;
  border:1px solid var(--border);
  border-radius:var(--r-pill);
  background:var(--paper);
  color:var(--ink-2);
  padding:8px 14px;
  font-family:var(--sans);
  font-size:12.5px;
  font-weight:800;
  cursor:pointer;
}
.filter-reset:hover{
  color:var(--okoshi-accent);
  border-color:var(--okoshi-accent);
}
.filter-explain{
  margin:-4px 0 18px;
  max-width:780px;
  color:var(--ink-3);
  font-family:var(--sans);
  font-size:12.5px;
  line-height:1.75;
}
.result-toolbar{
  display:flex;
  justify-content:space-between;
  gap:16px;
  align-items:flex-start;
  margin:0 0 14px;
}
.result-toolbar .rescount{
  margin:0;
}
.result-actions{
  display:flex;
  align-items:flex-start;
  justify-content:flex-end;
  gap:10px;
  flex-wrap:wrap;
  max-width:560px;
}
.result-toolbar .hint{
  margin:0;
  max-width:420px;
  color:var(--ink-3);
  font-family:var(--sans);
  font-size:12px;
  line-height:1.7;
  text-align:right;
}
.filter-share{
  min-height:36px;
  border:1px solid var(--okoshi-accent);
  border-radius:var(--r-pill);
  background:var(--okoshi-accent);
  color:#fff;
  padding:8px 14px;
  font-family:var(--sans);
  font-size:12px;
  font-weight:900;
  letter-spacing:.03em;
  cursor:pointer;
  white-space:nowrap;
}
.filter-share:hover{
  filter:brightness(.95);
}
.regions .pnames{
  grid-template-columns:repeat(2,minmax(120px,1fr));
}
.regions .pname{
  gap:8px;
  min-width:0;
  white-space:nowrap;
}
.regions .pname span{
  min-width:0;
  overflow:hidden;
  text-overflow:ellipsis;
}
.regions .pname small{
  flex:0 0 auto;
}
@media(max-width:520px){
  .regions .pnames{
    grid-template-columns:1fr;
  }
}
.share-feedback{
  min-height:18px;
  color:var(--okoshi-accent);
  font-family:var(--sans);
  font-size:12px;
  font-weight:800;
  line-height:36px;
}
.recruitment-card[hidden]{
  display:none!important;
}
.recruitment-list-page .recruitment-grid{
  gap:10px;
}
.recruitment-list-page .recruitment-card{
  min-height:0;
  padding:16px 18px;
}
.recruitment-list-page .recruitment-card h3{
  font-size:17px;
  line-height:1.35;
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
}
.recruitment-list-page .summary{
  display:-webkit-box;
  -webkit-line-clamp:3;
  -webkit-box-orient:vertical;
  overflow:hidden;
  margin-top:8px;
}
.card-checked{
  font-family:var(--mono);
  font-size:10px;
  letter-spacing:.03em;
  color:var(--ink-3);
  line-height:1.55;
  margin:0 0 12px;
}
.card-warning{
  color:#8a4b00;
  font-size:12px;
  line-height:1.6;
  margin:0 0 10px;
}
.recruitment-badges{
  display:flex;
  flex-wrap:wrap;
  gap:6px;
  margin:10px 0 12px;
}
.condition-badge{
  display:inline-flex;
  align-items:center;
  min-height:26px;
  border:1px solid var(--border);
  border-radius:var(--r-pill);
  background:var(--paper);
  color:var(--ink-2);
  padding:5px 9px;
  font-family:var(--sans);
  font-size:11.5px;
  font-weight:800;
  line-height:1;
}
.condition-badge.is-urgent{
  color:#8b3b1c;
  border-color:#d7a077;
  background:#fff2e7;
}
.card-badges{
  display:flex;
  flex-wrap:wrap;
  justify-content:flex-end;
  gap:6px;
  min-width:96px;
}
.source-badge{
  display:inline-flex;
  align-items:center;
  border-radius:var(--r-bdg);
  padding:6px 8px;
  font-family:var(--sans);
  font-size:11px;
  font-weight:800;
  line-height:1;
  white-space:nowrap;
}
.source-official{
  color:var(--okoshi-accent-dark);
  background:#e5f1ed;
  border:1px solid rgba(19,116,121,.35);
}
.card-facts .fact em{
  display:block;
  margin-top:4px;
  color:var(--ink-3);
  font-family:var(--sans);
  font-size:10.5px;
  font-style:normal;
  line-height:1.45;
}
.card-source{
  margin:0 0 10px;
  border:1px solid var(--border);
  border-radius:8px;
  background:rgba(255,255,255,.55);
  padding:8px 10px;
}
.card-source summary{
  cursor:pointer;
  color:var(--okoshi-accent);
  font-family:var(--sans);
  font-size:11.5px;
  font-weight:800;
}
.card-source p{
  margin:8px 0 0;
  color:var(--ink-3);
  font-family:var(--sans);
  font-size:11px;
  line-height:1.65;
}

.status-badge{
  font-family:var(--sans);
  font-size:11px;
  font-weight:700;
  line-height:1;
  border-radius:var(--r-bdg);
  padding:6px 8px;
  white-space:nowrap;
}
.status-active{color:#fff;background:var(--okoshi-accent);}
.status-rolling{color:var(--okoshi-accent-dark);background:var(--okoshi-soft);border:1px solid var(--okoshi-accent);}
.status-open{color:#fff;background:var(--okoshi-accent);}
.status-open_rolling{color:var(--okoshi-accent-dark);background:var(--okoshi-soft);border:1px solid var(--okoshi-accent);}
.status-scheduled{color:var(--ink);background:#f3e4cc;border:1px solid #d9a25f;}
.status-closed{color:var(--ink-3);background:var(--bg-soft);border:1px solid var(--border);}
.status-expired{color:var(--ink-3);background:var(--bg-soft);border:1px solid var(--border);}
.status-unknown,.status-not_found{color:var(--ink-3);background:transparent;border:1px solid var(--border);}

.recruitment-card.is-expired{
  opacity:.72;
}
.recruitment-card.is-expired .buttonlink{
  background:var(--bg-soft);
  color:var(--ink-3);
}

.result-tools{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  flex-wrap:wrap;
}
.toggle-filter{
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-family:var(--sans);
  font-size:12px;
  font-weight:800;
  color:var(--ink-2);
  cursor:pointer;
  user-select:none;
}
.toggle-filter input{
  width:16px;
  height:16px;
  accent-color:var(--okoshi-accent);
}
.inline-toggle{
  border:1px solid var(--border);
  border-radius:999px;
  background:rgba(255,255,255,.72);
  padding:8px 12px;
}

.theme-cloud{
  display:flex;
  flex-wrap:wrap;
  gap:9px;
}
.theme-pill{
  font-family:var(--sans);
  font-size:12px;
  color:var(--ink-2);
  background:var(--paper);
  border:1px solid var(--border);
  border-radius:var(--r-pill);
  padding:7px 12px;
  cursor:pointer;
}
.theme-pill:hover,.theme-pill.active{
  color:#fff;
  background:var(--okoshi-accent);
  border-color:var(--okoshi-accent);
}

.ranking-controls{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  gap:12px;
  padding-top:0;
}
.select-label{
  font-family:var(--mono);
  font-size:10px;
  letter-spacing:.14em;
  color:var(--ink-3);
  text-transform:uppercase;
}
.ranking-select{
  min-width:220px;
  border:1px solid var(--border);
  border-radius:var(--r-pill);
  background:var(--paper);
  color:var(--ink);
  padding:10px 14px;
  font-family:var(--sans);
  font-size:14px;
  font-weight:700;
}
.ranking-layout{
  display:grid;
  grid-template-columns:1fr;
  gap:18px;
}
.ranking-switch{
  display:flex;
  width:100%;
  max-width:420px;
  margin:0 0 10px;
  padding:4px;
  border:1px solid var(--border);
  border-radius:var(--r-pill);
  background:var(--paper);
}
.ranking-tab{
  flex:1 1 0;
  border:0;
  border-radius:var(--r-pill);
  background:transparent;
  color:var(--ink-2);
  cursor:pointer;
  font-family:var(--sans);
  font-size:13px;
  font-weight:800;
  line-height:1.2;
  padding:10px 12px;
}
.ranking-tab.active{
  background:var(--okoshi-accent);
  color:#fff;
}
.ranking-meta{
  margin:0 0 18px;
  color:var(--ink-3);
  font-family:var(--mono);
  font-size:11px;
  letter-spacing:.08em;
}
@media(min-width:980px){
  .ranking-layout{grid-template-columns:repeat(2,minmax(0,1fr));}
  .ranking-switch,
  .ranking-meta{display:none;}
}
@media(max-width:979px){
  .ranking-panel[data-ranking-panel]{
    display:none;
  }
  .ranking-panel[data-ranking-panel].active{
    display:block;
  }
}
.ranking-panel{
  background:var(--paper);
  border:1px solid var(--border);
  border-top:3px solid var(--okoshi-accent);
  border-radius:2px 2px var(--r-card) var(--r-card);
  overflow:hidden;
}
.ranking-title{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:12px;
  padding:18px 20px 14px;
  border-bottom:1px solid var(--border-soft);
}
.ranking-title h3{
  font-family:var(--serif);
  font-size:22px;
  line-height:1.25;
  margin:0;
}
.ranking-title span{
  font-family:var(--mono);
  font-size:10px;
  letter-spacing:.12em;
  color:var(--ink-3);
  white-space:nowrap;
  text-transform:uppercase;
}
.ranking-table{
  display:grid;
  grid-template-columns:1fr;
}
.ranking-row{
  display:grid;
  grid-template-columns:38px minmax(0,1fr) 86px;
  gap:12px;
  align-items:center;
  min-height:66px;
  padding:12px 16px;
  color:inherit;
  text-decoration:none;
  border-bottom:1px solid var(--border-soft);
}
.ranking-row[hidden]{
  display:none!important;
}
.ranking-row:last-child{border-bottom:0;}
.ranking-row:hover{background:var(--bg-soft);}
.rank-num{
  font-family:var(--mono);
  font-size:12px;
  color:var(--okoshi-accent);
  letter-spacing:.08em;
}
.rank-main b{
  display:block;
  font-family:var(--serif);
  font-size:17px;
  line-height:1.25;
}
.rank-main small{
  display:block;
  font-family:var(--mono);
  font-size:9px;
  line-height:1.55;
  letter-spacing:.04em;
  color:var(--ink-3);
  margin-top:3px;
}
.rank-value{
  font-family:var(--serif);
  font-size:24px;
  text-align:right;
  white-space:nowrap;
}

.muni-metrics{
  display:grid;
  grid-template-columns:repeat(3,64px);
  gap:6px;
  align-self:center;
}
.metric-pill{
  display:flex;
  flex-direction:column;
  justify-content:center;
  align-items:center;
  min-height:58px;
  border:1px solid var(--border);
  border-radius:8px;
  background:var(--bg-soft);
  color:var(--ink);
}
.metric-pill b{
  font-family:var(--serif);
  font-size:22px;
  line-height:1;
}
.metric-share b{
  font-size:18px;
}
.metric-pill small{
  font-family:var(--mono);
  font-size:9px;
  letter-spacing:.08em;
  color:var(--ink-3);
  margin-top:5px;
}
.metric-members{
  background:var(--okoshi-accent);
  border-color:var(--okoshi-accent);
  color:#fff;
}
.metric-members small{color:rgba(255,255,255,.82);}
.metric-strong{
  background:#f3e4cc;
  border-color:#d9a25f;
}

.compare-table{
  border:1px solid var(--border);
  border-radius:var(--r-card);
  overflow:hidden;
  background:var(--paper);
}
.compare-row{
  display:grid;
  grid-template-columns:minmax(0,1fr) repeat(3,82px);
  gap:8px;
  align-items:center;
  min-height:62px;
  padding:10px 14px;
  color:inherit;
  text-decoration:none;
  border-bottom:1px solid var(--border-soft);
}
.compare-row:last-child{border-bottom:0;}
.compare-row:hover{background:var(--bg-soft);}
.compare-row.is-current{
  background:var(--okoshi-soft);
  box-shadow:inset 3px 0 0 var(--okoshi-accent);
}
.compare-name{
  font-family:var(--serif);
  font-size:17px;
  line-height:1.25;
}
.compare-name small{
  display:block;
  font-family:var(--mono);
  font-size:9px;
  letter-spacing:.05em;
  color:var(--ink-3);
  margin-top:4px;
}
.compare-stat{
  text-align:right;
}
.compare-stat b{
  display:block;
  font-family:var(--serif);
  font-size:20px;
  line-height:1;
}
.compare-stat small{
  display:block;
  font-family:var(--mono);
  font-size:8px;
  letter-spacing:.08em;
  color:var(--ink-3);
  margin-top:5px;
}

.okoshi-detail{
  background:var(--paper);
  border:1px solid var(--border);
  border-top:3px solid var(--okoshi-accent);
  border-radius:2px 2px var(--r-card) var(--r-card);
  padding:24px;
  margin-bottom:18px;
}
.detail-head{
  display:grid;
  grid-template-columns:1fr;
  gap:20px;
}
@media(min-width:820px){
  .detail-head{grid-template-columns:1.2fr .8fr;}
}
.detail-head h2{
  font-family:var(--serif);
  font-size:clamp(28px,4vw,42px);
  line-height:1.12;
  margin:8px 0 0;
}
.detail-stats{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:1px;
  background:var(--border);
  border:1px solid var(--border);
  border-radius:var(--r-card);
  overflow:hidden;
}
@media(max-width:720px){
  .detail-stats{
    grid-template-columns:1fr;
  }
}
.detail-stats .stat{min-height:148px;}
.detail-stats .stat-link{
  display:flex;
  flex-direction:column;
  justify-content:center;
  color:inherit;
  text-decoration:none;
}
.detail-stats .stat-link small{
  font-family:var(--sans);
  font-size:11px;
  color:var(--okoshi);
  margin-top:8px;
}
.detail-stats .stat-link:hover .val{
  color:var(--okoshi);
}
.detail-stats .stat-date{
  display:block;
  margin-top:8px;
  font-family:var(--sans);
  font-size:11px;
  line-height:1.45;
  color:var(--ink-3);
}
.detail-stats .stat-link .stat-date{
  color:var(--ink-3);
}
.detail-lead{
  font-family:var(--sans);
  font-size:13px;
  color:var(--ink-2);
  line-height:1.8;
  margin:12px 0 0;
}
.support-list{
  display:flex;
  flex-wrap:wrap;
  gap:7px;
  margin-top:12px;
}
.support-list .chip{background:var(--okoshi-soft);}
.data-badges{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin:10px 0 0;
}
.data-badge{
  display:inline-flex;
  align-items:center;
  gap:7px;
  max-width:100%;
  border:1px solid var(--border);
  background:rgba(255,255,255,.62);
  border-radius:var(--r-pill);
  padding:7px 10px;
  font-family:var(--sans);
  font-size:12px;
  color:var(--ink-2);
  line-height:1.45;
  overflow-wrap:anywhere;
}
.data-badge b{
  flex:0 0 auto;
  font-family:var(--mono);
  font-size:10px;
  letter-spacing:.12em;
  color:var(--okoshi);
  text-transform:uppercase;
}
.mini-section{margin-top:24px;}
.mini-section h3{
  font-family:var(--serif);
  font-size:19px;
  margin:0 0 12px;
}
.source-note{
  font-family:var(--sans);
  font-size:12px;
  color:var(--ink-3);
  line-height:1.7;
  margin-top:16px;
}
.source-note a{
  color:var(--okoshi);
  text-decoration:underline;
  text-underline-offset:3px;
}
.data-sources{
  margin-top:34px;
  border-top:1px solid var(--border);
  padding-top:30px;
}
.source-date-list{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin:0 0 16px;
}
.source-date-list span{
  display:inline-flex;
  align-items:center;
  gap:8px;
  border:1px solid var(--border);
  border-radius:var(--r-pill);
  background:var(--bg-soft);
  padding:8px 11px;
  font-family:var(--sans);
  font-size:12px;
  color:var(--ink-2);
  line-height:1.45;
}
.source-date-list b{
  font-family:var(--mono);
  font-size:10px;
  letter-spacing:.12em;
  color:var(--okoshi);
  text-transform:uppercase;
}
.section-head.compact{
  margin-bottom:18px;
}
.source-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:12px;
}
.source-card{
  background:#fff;
  border:1px solid var(--border);
  border-radius:var(--r-card);
  padding:18px;
  min-height:186px;
}
.source-label{
  font-family:var(--mono);
  color:var(--okoshi);
  font-size:11px;
  font-weight:800;
  letter-spacing:.12em;
  text-transform:uppercase;
  margin-bottom:10px;
}
.source-card h3{
  font-family:var(--serif);
  font-size:20px;
  line-height:1.35;
  margin:0 0 8px;
}
.source-date{
  font-family:var(--mono);
  font-size:11px;
  color:var(--ink-3);
  margin:0 0 10px;
}
.source-card p{
  font-family:var(--sans);
  font-size:12.5px;
  line-height:1.75;
  color:var(--ink-2);
  margin:0 0 12px;
}
.source-card a{
  font-family:var(--sans);
  font-size:12px;
  font-weight:800;
  color:var(--okoshi);
  text-decoration:underline;
  text-underline-offset:3px;
}
.update-policy{
  margin-top:18px;
  background:var(--okoshi-soft);
  border:1px solid rgba(31,111,120,.24);
  border-radius:var(--r-card);
  padding:18px;
}
.update-policy h3{
  font-family:var(--serif);
  font-size:22px;
  margin:0 0 8px;
}
.update-policy p{
  font-family:var(--sans);
  font-size:13px;
  line-height:1.8;
  color:var(--ink-2);
  margin:0;
}
.update-policy p + p{
  margin-top:8px;
}
.correction-hero{
  padding-bottom:44px;
}
.correction-grid .glyph .g{
  font-family:var(--mono);
}
.request-template{
  margin:0;
  padding:18px;
  border:1px solid var(--border);
  border-left:4px solid var(--okoshi-accent);
  border-radius:var(--r-card);
  background:#fff;
  color:var(--ink-2);
  font-family:var(--mono);
  font-size:12px;
  line-height:1.9;
  white-space:pre-wrap;
}
.similar-list{
  display:grid;
  grid-template-columns:1fr;
  gap:10px;
}
@media(min-width:680px){
  .similar-list{grid-template-columns:repeat(3,1fr);}
}

@media(max-width:720px){
  .hero{
    padding:34px 0 26px;
  }
  .hero h1.big{
    font-size:34px;
  }
  .hero-actions{
    grid-template-columns:1fr;
  }
  .hero-actions a{
    flex-direction:row;
    justify-content:space-between;
    align-items:baseline;
  }
  .filters{
    align-items:stretch;
  }
  .filters .searchbox,
  .recruitment-filters .searchbox{
    max-width:none!important;
    width:100%;
    flex-basis:100%;
  }
  .filters .sel,
  .filter-reset{
    width:100%;
  }
  .result-toolbar{
    display:block;
  }
  .result-actions{
    justify-content:flex-start;
    margin-top:8px;
  }
  .result-toolbar .hint{
    margin-top:6px;
    text-align:left;
  }
  .recruitment-card{
    padding:16px;
    min-height:0;
    width:100%;
  }
  .card-facts{
    grid-template-columns:1fr;
  }
  .ranking-controls{
    align-items:stretch;
    flex-direction:column;
  }
  .ranking-select{width:100%;}
  .ranking-switch{
    max-width:none;
  }
  .ranking-tab{
    font-size:12px;
    padding:9px 8px;
  }
  .ranking-row{
    grid-template-columns:28px minmax(0,1fr);
  }
  .rank-value{
    grid-column:2;
    text-align:left;
    font-size:20px;
  }
  .muni{
    flex-direction:column;
  }
  .muni-metrics{
    grid-template-columns:repeat(3,minmax(0,1fr));
    width:100%;
  }
  .source-grid{
    grid-template-columns:1fr;
  }
  .source-card{
    min-height:0;
  }
  .compare-row{
    grid-template-columns:minmax(0,1fr) repeat(3,58px);
    padding:10px;
  }
  .compare-stat b{font-size:17px;}
}

/* いま応募できる募集 ブロック（ヒーロー直下の入口） */
.opennow-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:12px;
}
@media(min-width:640px){
  .opennow-grid{grid-template-columns:repeat(2,1fr);}
}
@media(min-width:980px){
  .opennow-grid{grid-template-columns:repeat(3,1fr);}
}
.opennow-card{
  display:flex;
  flex-direction:column;
  gap:8px;
  background:var(--paper);
  border:1px solid var(--border);
  border-top:3px solid var(--okoshi-accent);
  border-radius:2px 2px var(--r-card) var(--r-card);
  padding:16px 18px;
  min-width:0;
  text-decoration:none;
  color:inherit;
  transition:border-color .15s ease, transform .15s ease;
}
.opennow-card:hover{border-color:var(--okoshi-accent);transform:translateY(-2px);}
.opennow-card .on-place{
  font-size:12px;
  letter-spacing:.04em;
  color:var(--ink-3);
}
.opennow-card .on-title{
  font-family:var(--serif);
  font-weight:600;
  font-size:16px;
  line-height:1.45;
  color:var(--ink);
}
.opennow-card .on-facts{
  display:flex;
  flex-wrap:wrap;
  gap:6px 10px;
  margin-top:auto;
  font-size:12.5px;
}
.opennow-card .on-deadline{
  font-weight:700;
  color:var(--okoshi-accent-dark);
}
.opennow-card .on-reward,
.opennow-card .on-term{color:var(--ink-2);}
.opennow-more{
  display:inline-block;
  margin-top:16px;
  font-weight:600;
  color:var(--okoshi-accent-dark);
  text-decoration:none;
}
.opennow-more:hover{text-decoration:underline;}

/* SNAPSHOT を操作可能に: テーマバー=テーマ絞り込みボタン / 締切リスト=募集リンク */
.bars .barrow{
  display:grid;
  grid-template-columns:96px 1fr 36px;
  align-items:center;
  gap:10px;
  width:100%;
  background:transparent;
  border:0;
  padding:6px 4px;
  margin:0 -4px;
  border-radius:6px;
  font:inherit;
  text-align:left;
  cursor:pointer;
  transition:background .12s ease;
}
.bars .barrow:hover{background:var(--okoshi-soft);}
.bars .barrow:hover .bn{color:var(--okoshi-accent-dark);}
.bars .barrow .bp{text-align:right;}
a.deadline-item{
  text-decoration:none;
  color:inherit;
  cursor:pointer;
  transition:background .12s ease;
  border-radius:6px;
  margin:0 -6px;
  padding-left:6px;
  padding-right:6px;
}
a.deadline-item:hover{background:var(--okoshi-soft);}
a.deadline-item:hover strong{color:var(--okoshi-accent-dark);}

/* 募集フィルタ: 主要3つ(検索・都道府県・テーマ)を常時表示、それ以外は折りたたみ。モバイルの選択肢過多を解消 */
.recruitment-filters{display:block;}
.filters-primary{display:flex;flex-wrap:wrap;gap:10px;align-items:center;}
.advanced-filters{margin-top:10px;}
.advanced-filters > summary{
  display:inline-flex;
  align-items:center;
  gap:6px;
  width:fit-content;
  cursor:pointer;
  list-style:none;
  padding:9px 16px;
  border:1px solid var(--border);
  border-radius:var(--r-pill);
  font-size:13px;
  font-weight:600;
  color:var(--okoshi-accent-dark);
  background:var(--paper);
}
.advanced-filters > summary::-webkit-details-marker{display:none;}
.advanced-filters > summary::after{content:"▾";font-size:11px;}
.advanced-filters[open] > summary::after{content:"▴";}
.advanced-filters > summary:hover{border-color:var(--okoshi-accent);}
.advanced-grid{display:flex;flex-wrap:wrap;gap:10px;margin-top:12px;}
.filter-controls{display:flex;flex-wrap:wrap;gap:12px 18px;align-items:center;margin-top:12px;}
@media(max-width:560px){
  .filters-primary .searchbox{flex:1 1 100%;max-width:none;}
  .filters-primary .sel{flex:1 1 100%;}
  .advanced-filters{margin-top:12px;}
  .advanced-grid .sel{flex:1 1 100%;}
}
