/* =========================================================
   よさこい津軽 共通スタイル
   - モバイルファースト / レスポンシブ
   - 祭り（鳴子）の朱色を差し色に、藍を基調
   - OS標準フォントのみ（追加読み込みなし）
   ========================================================= */

:root{
  --ink:#1b1b1b;
  --ink-soft:#4a4a4a;
  --bg:#ffffff;
  --paper:#f7f3ec;      /* 温かみのある地色 */
  --red:#c8102e;        /* 祭りの朱 */
  --red-dark:#a00d24;
  --indigo:#20395c;     /* 藍：見出し・リンク補助 */
  --gold:#b8892f;
  --line:#e3ddd2;

  /* 本文：OS標準ゴシック（軽量）。見出し：しっぽり明朝B1。タイトル：筆文字（勇字宿） */
  --font-body:"Hiragino Kaku Gothic ProN","Hiragino Sans","Yu Gothic","YuGothic",Meiryo,system-ui,sans-serif;
  --font-disp:"Shippori Mincho B1","Yu Mincho","Hiragino Mincho ProN",serif;
  --font-brush:"Yuji Syuku","Yu Mincho","Hiragino Mincho ProN",serif;

  --maxw:960px;
}

*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  margin:0;
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--bg);
  line-height:1.85;
}
img{max-width:100%;height:auto;display:block}
a{color:var(--indigo)}
a:hover{color:var(--red-dark)}

.container{max-width:var(--maxw);margin:0 auto;padding:0 16px}

/* =========================================================
   ヘッダー（画像＋SVG装飾で豪華に。タイトルは実テキスト）
   ========================================================= */
.site-header{
  position:relative;
  overflow:hidden;
  background:var(--indigo);
}
/* ▼ ヘッダー背景スライドショー：hero1〜4.jpg を3秒ごとに順番で切替（差し替えは同名で置換） */
.hero-slideshow{position:absolute;inset:0;z-index:0}
.hero-slideshow .slide{
  position:absolute;inset:0;background-position:center 42%;background-size:cover;background-repeat:no-repeat;
  opacity:0;animation:heroFade 12s infinite;
}
.hero-slideshow .slide:nth-child(1){animation-delay:0s}
.hero-slideshow .slide:nth-child(2){animation-delay:3s}
.hero-slideshow .slide:nth-child(3){animation-delay:6s}
.hero-slideshow .slide:nth-child(4){animation-delay:9s}
@keyframes heroFade{0%{opacity:0}4%{opacity:1}25%{opacity:1}29%{opacity:0}100%{opacity:0}}
/* 文字可読性のための暗色オーバーレイ */
.hero-slideshow::after{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg, rgba(18,26,44,.48), rgba(18,26,44,.74))}
/* 動きを控える設定の利用者には1枚目を静止表示 */
@media (prefers-reduced-motion: reduce){
  .hero-slideshow .slide{animation:none;opacity:0}
  .hero-slideshow .slide:nth-child(1){opacity:1}
}
.site-header .container{
  position:relative;z-index:2;
  min-height:clamp(258px,31vw,340px);
  padding:0 16px;
}
/* 公式タイトル画像（縦書き・白抜き）：右寄せ・縦中央、なるべく大きく */
.site-title{position:absolute;top:50%;right:clamp(18px,5vw,60px);transform:translateY(-50%);margin:0;z-index:2}
.site-title a{display:block;line-height:0}
.title-img{
  display:block;height:clamp(214px,34vw,308px);width:auto;
  filter:drop-shadow(0 3px 15px rgba(0,0,0,.6));
}
/* 左下のテキストブロック（最上部に「第25回よさこい津軽」＝游ゴシック小さめ、続けて連絡先） */
.header-text{
  position:absolute;left:clamp(14px,3.2vw,28px);bottom:clamp(14px,3vw,24px);z-index:3;
  max-width:56%;
}
.header-text .edition-label{
  margin:0 0 3px;
  font-family:"Yu Gothic","YuGothic","Hiragino Kaku Gothic ProN","Hiragino Sans",Meiryo,sans-serif;
  font-weight:700;font-size:clamp(14px,3.4vw,18px);letter-spacing:.06em;
  color:#fff;text-shadow:0 1px 8px rgba(0,0,0,.7);
}
.header-text .event-date{
  margin:0 0 10px;
  font-family:"Yu Gothic","YuGothic","Hiragino Kaku Gothic ProN","Hiragino Sans",Meiryo,sans-serif;
  font-weight:600;font-size:clamp(12px,2.9vw,15px);letter-spacing:.04em;
  color:#fff;text-shadow:0 1px 8px rgba(0,0,0,.7);
}
.header-text .office-contact{
  margin:0;color:rgba(255,255,255,.9);font-size:clamp(10px,2.3vw,12.5px);line-height:1.6;
  text-shadow:0 1px 6px rgba(0,0,0,.6);
}
/* 鳴子（なるこ）モチーフを背景に薄く敷く */
.header-motif{position:absolute;inset:0;z-index:1;opacity:.14;pointer-events:none}
/* 下辺の朱と金茶のアクセント帯 */
.site-header::after{
  content:"";position:absolute;left:0;right:0;bottom:0;height:6px;z-index:3;
  background:repeating-linear-gradient(90deg,var(--red) 0 24px,var(--gold) 24px 28px);
}

/* =========================================================
   ナビ
   ========================================================= */
.site-nav{background:var(--indigo);border-bottom:1px solid rgba(0,0,0,.1)}
.site-nav ul{
  max-width:var(--maxw);margin:0 auto;padding:0;list-style:none;
  display:grid;grid-template-columns:1fr 1fr;
}
@media(min-width:640px){.site-nav ul{grid-template-columns:repeat(4,1fr)}}
.site-nav a{
  display:block;text-align:center;color:#fff;text-decoration:none;
  padding:13px 6px;font-size:14px;font-weight:600;
  border-bottom:1px solid rgba(255,255,255,.12);
  border-right:1px solid rgba(255,255,255,.12);
}
.site-nav a:hover{background:rgba(255,255,255,.08);color:#fff}
.site-nav a.current{background:var(--red);color:#fff}

/* =========================================================
   本文共通
   ========================================================= */
main{padding:8px 0 8px}
.block{padding:18px 0}
.section-title{
  font-family:var(--font-disp);color:var(--indigo);font-size:clamp(20px,4.6vw,26px);
  border-left:7px solid var(--red);padding-left:12px;margin:30px 0 16px;
}
.sub-title{color:var(--red-dark);font-size:16px;margin:22px 0 6px}
.lead{font-size:16px}
.note{font-size:12.5px;color:var(--ink-soft)}
.plain{padding-left:1.2em;margin:0 0 8px}
.plain li{margin:4px 0}

/* =========================================================
   ヒーロー（ホーム）とポスター準備中エリア
   ========================================================= */
.hero{padding:24px 0 6px;text-align:center}
.hero .edition{font-family:var(--font-disp);color:var(--red-dark);font-weight:700;
  font-size:clamp(18px,4vw,24px);margin:0}
.hero .date{font-family:var(--font-disp);font-size:clamp(16px,3.4vw,20px);margin:6px 0}
.hero .note{margin:4px 0 18px}

.count-card{
  background:var(--paper);border:1px solid var(--line);border-radius:10px;
  padding:22px 18px;text-align:center;
}
.count-card .eyebrow{font-size:12px;letter-spacing:.22em;color:var(--red-dark);font-weight:700;margin:0}
.count-card .cdate{font-family:var(--font-disp);font-size:clamp(19px,4.4vw,26px);margin:6px 0 16px}
.countdown{display:flex;justify-content:center;gap:10px;flex-wrap:wrap}
.count-unit{background:#fff;border:1px solid var(--line);border-radius:8px;min-width:74px;padding:10px 6px}
.count-unit b{display:block;font-size:30px;font-family:var(--font-disp);color:var(--indigo);line-height:1}
.count-unit span{font-size:11px;color:var(--ink-soft)}
.count-card .cnote{font-size:12.5px;color:var(--ink-soft);margin:14px 0 0}
/* ポスター確定後に使う枠（点線） */
.poster-box{
  border:2px dashed var(--line);border-radius:10px;padding:40px 16px;
  text-align:center;color:#9a9a9a;font-size:13px;background:#fbf9f5;margin-top:6px;
}

/* お知らせ */
.news{list-style:none;padding:0;margin:0}
.news li{padding:12px 0;border-bottom:1px dotted var(--line);font-size:14.5px}
.news .date{display:inline-block;color:var(--red-dark);font-weight:700;font-size:12.5px;margin-right:10px}

/* 開催概要テーブル風 */
.info-table{width:100%;border-collapse:collapse;font-size:14.5px}
.info-table th,.info-table td{text-align:left;padding:10px 8px;border-bottom:1px solid var(--line);vertical-align:top}
.info-table th{width:34%;color:var(--indigo);white-space:nowrap}

/* =========================================================
   参加チーム（画像あり／文字のみ を1グリッドで両立）
   ========================================================= */
.team-grid{display:grid;grid-template-columns:1fr;gap:16px}
@media(min-width:700px){.team-grid{grid-template-columns:1fr 1fr}}
.team-card{border:1px solid var(--line);border-radius:10px;overflow:hidden;background:#fff;
  box-shadow:0 1px 3px rgba(0,0,0,.04)}
.team-card .thumb{aspect-ratio:16/10;width:100%;object-fit:cover;background:var(--paper)}
.team-card .body{padding:14px 16px}
.team-card h3{margin:0;font-size:17px;color:var(--indigo);line-height:1.4}
.team-card h3 .area{font-size:12px;color:var(--red-dark);margin-left:6px;font-weight:600}
.team-card .yomi{display:block;font-size:11px;color:var(--ink-soft);margin:2px 0 8px}
.team-card p{margin:0;font-size:14px}
/* ▼ 文字のみ版：写真枠を出さず左に朱の帯だけ立てる（画像未提出チーム用） */
.team-card--text{border-left:5px solid var(--red)}
.team-card--text .thumb{display:none}

/* 過去年度・名簿表示（文字のみの年度向け） */
.roster{columns:2;column-gap:24px;padding:0;margin:8px 0 0;list-style:none}
@media(max-width:520px){.roster{columns:1}}
.roster li{break-inside:avoid;padding:6px 0;border-bottom:1px dotted var(--line);font-size:14px}
.roster li .area{color:var(--red-dark);font-size:12px;margin-left:6px}

/* アーカイブリンク */
.archive-list{list-style:none;padding:0;margin:0;
  display:grid;grid-template-columns:1fr;gap:2px}
@media(min-width:560px){.archive-list{grid-template-columns:1fr 1fr}}
.archive-list li{padding:0}
.archive-list a{display:block;padding:11px 12px;border-bottom:1px dotted var(--line);
  text-decoration:none;font-size:14px}
.archive-list a:hover{background:var(--paper)}

/* =========================================================
   フッター（メールはJSで組み立て）
   ========================================================= */
.site-footer{background:var(--indigo);color:#fff;margin-top:40px;padding:26px 0}
.site-footer a{color:#fff}
.office{font-size:13px;line-height:1.9;margin:0 0 10px}
.office .mail{border-bottom:1px dotted rgba(255,255,255,.6)}
.copyright{font-size:11px;opacity:.7;margin:0}

/* フォーカス可視化 */
a:focus-visible,button:focus-visible{outline:3px solid var(--gold);outline-offset:2px}

@media(prefers-reduced-motion:reduce){*{scroll-behavior:auto}}

/* =========================================================
   ダウンロードボタン（PDF / Word）
   ========================================================= */
.dl-group{margin:12px 0 6px}
.dl-btn{
  display:inline-flex;align-items:center;gap:9px;
  background:var(--red);color:#fff;text-decoration:none;
  padding:12px 18px;border-radius:8px;font-weight:700;font-size:14.5px;
  margin:6px 10px 6px 0;box-shadow:0 1px 3px rgba(0,0,0,.16);
  transition:background .15s;
}
.dl-btn:hover{background:var(--red-dark);color:#fff}
.dl-btn svg{flex:0 0 auto}
.dl-btn .ext{font-size:11px;font-weight:600;opacity:.85;
  border:1px solid rgba(255,255,255,.6);border-radius:4px;padding:1px 6px;margin-left:2px}
/* 副ボタン（Word等） */
.dl-btn--sub{background:#fff;color:var(--indigo);border:1.5px solid var(--indigo)}
.dl-btn--sub:hover{background:var(--paper);color:var(--indigo)}
.dl-btn--sub .ext{border-color:var(--indigo);opacity:.7}
/* お申込みへ誘導する大きめボタン */
.cta-btn{
  display:inline-block;background:var(--indigo);color:#fff;text-decoration:none;
  padding:13px 26px;border-radius:8px;font-weight:700;font-size:15px;margin:8px 0;
}
.cta-btn:hover{background:#152a45;color:#fff}

/* =========================================================
   開催概要（イベント詳細ブロック・現行サイト寄りの明快な体裁）
   ========================================================= */
.event-detail{background:var(--paper);border:1px solid var(--line);border-radius:10px;padding:20px 20px 22px}
.event-detail h3{font-family:var(--font-disp);color:var(--red-dark);font-size:clamp(18px,4vw,22px);margin:0 0 12px}
.event-detail dl{margin:0;display:grid;grid-template-columns:auto 1fr;gap:0}
.event-detail dt{grid-column:1;color:var(--indigo);font-weight:700;font-size:14px;
  padding:9px 16px 9px 0;white-space:nowrap;border-bottom:1px solid var(--line)}
.event-detail dd{grid-column:2;margin:0;padding:9px 0;font-size:14.5px;border-bottom:1px solid var(--line)}
.event-detail dl>dt:last-of-type,.event-detail dl>dd:last-of-type{border-bottom:none}

/* =========================================================
   過去年度アーカイブ：年度ナビ＋見出しバッジ
   ========================================================= */
.past-badge{display:inline-block;background:var(--gold);color:#fff;font-size:12px;font-weight:700;
  padding:3px 12px;border-radius:99px;margin-bottom:6px}
.year-nav{display:flex;flex-wrap:wrap;gap:8px;margin:6px 0 4px}
.year-nav a{display:inline-block;padding:7px 12px;border:1px solid var(--line);border-radius:7px;
  text-decoration:none;font-size:13.5px;background:#fff}
.year-nav a:hover{background:var(--paper)}
.year-nav a.current{background:var(--indigo);color:#fff;border-color:var(--indigo)}
.back-link{display:inline-block;margin:18px 0 0;font-size:14px}

/* 名簿（2004）用のふりがな表示 */
.roster li .ruby{color:var(--ink-soft);font-size:12px;margin-left:6px}
