:root{
  --navy:#123a5e;      /* メイン（濃紺） */
  --teal:#1f7a8c;      /* アクセント */
  --magenta:#b5406b;   /* 染色イメージの差し色 */
  --bg:#f6f8fa;
  --card:#ffffff;
  --ink:#243444;
  --muted:#5b6b7a;
  --line:#e2e8ee;
}
*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  font-family:"Hiragino Kaku Gothic ProN","Yu Gothic",Meiryo,system-ui,sans-serif;
  color:var(--ink);
  background:var(--bg);
  line-height:1.8;
}
/* スマホ文字折り返しルール（全プロジェクト共通） */
p,li,dd,dt,h1,h2,h3,a,span,th,td{
  overflow-wrap:break-word;
  word-break:normal;
  line-break:strict;
}
img{max-width:100%;height:auto;}
a{color:var(--teal);}

/* ===== ヘッダー / ナビ ===== */
header.site{
  position:sticky;top:0;z-index:50;
  background:rgba(255,255,255,.95);
  backdrop-filter:blur(6px);
  border-bottom:1px solid var(--line);
}
.nav-inner{
  max-width:1040px;margin:0 auto;padding:10px 16px;
  display:flex;align-items:center;justify-content:space-between;gap:12px;
}
.brand{font-weight:700;color:var(--navy);font-size:15px;line-height:1.4;text-decoration:none;}
.brand small{display:block;font-weight:500;color:var(--muted);font-size:11px;}
nav ul{display:flex;flex-wrap:wrap;gap:14px;list-style:none;margin:0;padding:0;font-size:13px;}
nav a{color:var(--ink);text-decoration:none;}
nav a:hover{color:var(--teal);}
nav a.active{color:var(--teal);font-weight:700;border-bottom:2px solid var(--teal);padding-bottom:2px;}
.nav-toggle{display:none;}

/* ===== ヒーロー（トップページ） ===== */
.hero{
  position:relative;overflow:hidden;
  color:#fff;padding:84px 16px 76px;text-align:center;
}
.hero::before{
  content:"";position:absolute;inset:0;z-index:0;
  background:url("images/hero-okayama.png") center/cover no-repeat;
  animation:kenburns 20s ease-in-out infinite;
}
.hero::after{
  content:"";position:absolute;inset:0;z-index:1;
  background:linear-gradient(135deg,rgba(18,58,94,.70),rgba(31,122,140,.55));
}
.hero > *{position:relative;z-index:2;}
@keyframes kenburns{
  0%{transform:scale(1)}50%{transform:scale(1.08)}100%{transform:scale(1)}
}
.hero .kicker{letter-spacing:.15em;font-size:13px;opacity:.95;margin:0 0 10px;text-shadow:0 1px 6px rgba(0,0,0,.4);}
.hero h1{font-size:32px;margin:0 0 8px;line-height:1.35;text-shadow:0 2px 12px rgba(0,0,0,.45);}
.hero .theme{font-size:17px;opacity:.98;margin:6px 0 22px;text-shadow:0 1px 8px rgba(0,0,0,.45);}
.hero .facts,.hero .badge-live{text-shadow:0 1px 6px rgba(0,0,0,.35);}
.hero .facts{display:inline-flex;flex-wrap:wrap;gap:10px 22px;justify-content:center;font-size:15px;margin-bottom:22px;}
.hero .facts b{font-weight:700;}
.badge-live{
  display:inline-block;background:var(--magenta);color:#fff;
  padding:6px 14px;border-radius:999px;font-size:13px;font-weight:700;
}
.btn{
  display:inline-block;background:#fff;color:var(--navy);
  padding:12px 26px;border-radius:8px;font-weight:700;text-decoration:none;
  box-shadow:0 4px 14px rgba(0,0,0,.15);
}
.btn.primary{background:var(--magenta);color:#fff;}
.hero .btn{margin-top:6px;}

/* ===== 下層ページの見出し帯 ===== */
.page-head{
  background:linear-gradient(135deg,var(--navy),var(--teal));
  color:#fff;padding:42px 16px;text-align:center;
}
.page-head h1{font-size:26px;margin:0 0 6px;}
.page-head p{opacity:.9;font-size:14px;margin:0;}

/* ===== 本文 ===== */
main{max-width:1040px;margin:0 auto;padding:8px 16px 40px;}
section{scroll-margin-top:70px;padding:38px 0;border-bottom:1px solid var(--line);}
section:last-child{border-bottom:none;}
h2{color:var(--navy);font-size:22px;margin:0 0 18px;padding-left:12px;border-left:5px solid var(--teal);}
h3{color:var(--teal);font-size:17px;margin:22px 0 8px;}
.lead{color:var(--muted);}

.card{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:20px;box-shadow:0 1px 3px rgba(0,0,0,.03);}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:16px;}

table.info{width:100%;border-collapse:collapse;}
table.info th,table.info td{text-align:left;vertical-align:top;padding:12px 10px;border-bottom:1px solid var(--line);}
table.info th{width:130px;color:var(--navy);white-space:nowrap;background:#f0f5f9;font-weight:700;}

.todo{background:#fff8e6;border:1px dashed #e0b100;color:#8a6d00;font-size:12px;padding:2px 8px;border-radius:6px;display:inline-block;}

ul.prog{list-style:none;padding:0;margin:0;}
ul.prog li{padding:12px 0;border-bottom:1px dashed var(--line);}
ul.prog li b{color:var(--navy);}

.news li{padding:8px 0;border-bottom:1px dashed var(--line);list-style:none;}
.news{padding-left:0;}
.news .date{color:var(--magenta);font-weight:700;margin-right:10px;}

.center{text-align:center;}
.page-link-back{display:inline-block;margin-top:8px;font-size:14px;}

footer{background:var(--navy);color:#cdd9e5;padding:30px 16px;text-align:center;font-size:13px;}
footer a{color:#fff;}

/* ===== レスポンシブ ===== */
@media(max-width:720px){
  .hero h1{font-size:23px;}
  .page-head h1{font-size:21px;}
  .grid2{grid-template-columns:1fr;}
  nav ul{
    display:none;position:absolute;top:56px;left:0;right:0;
    flex-direction:column;background:#fff;border-bottom:1px solid var(--line);
    padding:12px 16px;gap:12px;
  }
  nav ul.open{display:flex;}
  .nav-toggle{display:inline-block;background:none;border:1px solid var(--line);border-radius:6px;padding:6px 10px;font-size:18px;color:var(--navy);}
  table.info th{width:100px;font-size:13px;}
}
