:root{
  /* 基調：濃すぎないネイビー／グレー（変数名は据え置き） */
  --green:#4a5d80; --green-d:#3a4a67; --ink:#1f2430; --muted:#6e7686;
  --line:#e3e6ec; --bg:#f5f6f9; --card:#fff;
  --blue:#3a6ea5; --red:#c4504e; --gray:#9098a6; --gold:#caa23a;
}
*{box-sizing:border-box}
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.6;font-size:15px}
a{color:var(--green-d);text-decoration:none}
a:hover{text-decoration:underline}
.wrap{max-width:920px;margin:0 auto;padding:0 14px}

/* header */
header.site{background:var(--green);color:#fff;position:sticky;top:0;z-index:20;box-shadow:0 1px 6px rgba(0,0,0,.15)}
header.site .wrap{display:flex;align-items:center;gap:10px;height:54px}
header.site .logo{font-weight:800;font-size:17px;color:#fff;letter-spacing:.5px}
header.site .logo small{display:block;font-weight:400;font-size:10px;opacity:.85;letter-spacing:0}
nav.tabs{background:var(--green-d);position:sticky;top:54px;z-index:19}
nav.tabs .wrap{display:flex;gap:2px;overflow-x:auto;-webkit-overflow-scrolling:touch}
nav.tabs a{color:#d7deec;white-space:nowrap;padding:11px 13px;font-size:13.5px;font-weight:600;border-bottom:3px solid transparent}
nav.tabs a.active{color:#fff;border-bottom-color:#ffd34d}
nav.tabs a:hover{text-decoration:none;color:#fff}

main{padding:18px 0 60px}
h1.page{font-size:21px;margin:4px 0 4px}
.lead{color:var(--muted);font-size:13px;margin:0 0 18px}
h2.sec{font-size:16px;margin:26px 0 12px;padding-left:10px;border-left:4px solid var(--green)}

/* match block（同日・同大会・同会場の枠／縦軸=時間）*/
.mblock{background:var(--card);border:1px solid var(--line);border-radius:12px;margin-bottom:14px;overflow:hidden}
.bhead{background:#eef1f7;padding:10px 15px}
.bhead .t{font-weight:700;font-size:13.5px;color:var(--green-d);line-height:1.45}
.bhead .v{font-size:12px;color:var(--muted);margin-top:2px}
.imatch{display:flex;gap:12px;padding:13px 15px;border-top:1px solid var(--line)}
.imatch .time{flex:0 0 44px;font-variant-numeric:tabular-nums;font-weight:700;color:var(--green-d);font-size:13.5px;padding-top:1px}
.imatch .body{flex:1;min-width:0}
.mc{border-top:1px solid var(--line)}
.mc .imatch{border-top:none}

/* match card (legacy) */
.card{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:13px 15px;margin-bottom:11px}
.card .meta{display:flex;flex-wrap:wrap;gap:8px;align-items:center;font-size:12px;color:var(--muted);margin-bottom:9px}
.badge{font-size:11px;font-weight:700;padding:2px 8px;border-radius:20px;color:#fff}
.badge.s-終了{background:var(--gray)}
.badge.s-予定{background:var(--blue)}
.badge.s-開催中{background:var(--red);animation:pulse 1.6s infinite}
@keyframes pulse{50%{opacity:.55}}
.badge.grade{background:#eef0f5;color:var(--green-d);font-weight:700}
/* 対戦：横1列（チーム名 得点 - 得点 チーム名）*/
.line{display:flex;align-items:center;gap:9px;padding:4px 0;flex-wrap:nowrap}
.line .tm{flex:1;font-weight:700;font-size:15px;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.line .tm.home{text-align:right}
.line .tm.away{text-align:left}
.line .tm a{display:inline}
.line .tm.win{color:var(--green-d)}
.line .sc{font-variant-numeric:tabular-nums;font-weight:800;font-size:20px;min-width:20px;text-align:center}
.line .sc.win{color:var(--green)}
.line .sep{color:var(--muted);font-weight:700}
.line .vsmid{color:var(--muted);font-size:12px;font-weight:700;padding:0 2px}
.halfline{text-align:center;font-size:11.5px;color:var(--muted);margin-top:4px;line-height:1.5}
.pk{font-size:12.5px;color:var(--red);font-weight:700;text-align:center;margin-top:4px}
/* legacy row */
.row{display:grid;grid-template-columns:1fr auto;align-items:center;gap:6px;padding:3px 0}
.half{font-size:11px;color:var(--muted)}
.tname-link{border-bottom:1px dashed #bcc4d4}
.vs{text-align:center;color:var(--muted);font-size:12px;padding:2px 0}
.src{font-size:11px;color:var(--gray);margin-top:7px}
.srcbox{margin-top:16px;display:flex;flex-direction:column;gap:6px;align-items:flex-start}
.pdflink{display:inline-flex;align-items:center;gap:6px;background:var(--green-d);color:#fff;font-weight:700;font-size:13.5px;padding:10px 16px;border-radius:9px;line-height:1.3;box-shadow:0 1px 3px rgba(0,0,0,.18)}
.pdflink:hover{background:var(--green)}
.srcnote{font-size:11px;color:var(--gray);line-height:1.5}
.preview{margin-top:8px;background:#eef1f7;border-left:3px solid var(--green);border-radius:0 7px 7px 0;padding:8px 11px;font-size:12.5px;color:var(--ink);line-height:1.55}
.preview b{color:var(--green-d)}
.tdesc{font-size:13.5px;line-height:1.75;color:var(--ink);background:#f4f6fa;border-radius:9px;padding:11px 14px;margin:4px 0 14px}
.tdesc-src{font-size:11.5px;color:var(--gray);margin-left:4px}
.unis{display:flex;flex-wrap:wrap;gap:12px}
.uni{background:#fff;border:1px solid var(--line);border-radius:11px;padding:11px 14px;min-width:150px}
.uni-name{font-weight:700;font-size:12px;color:var(--green-d);margin-bottom:8px}
.uni-parts{display:flex;flex-direction:column;gap:7px}
.upart{display:flex;align-items:center;gap:8px;font-size:13px}
.upart .sw{width:18px;height:18px;border-radius:5px;border:1px solid rgba(0,0,0,.12);flex:0 0 auto}
.upart .ul{color:var(--muted);flex:0 0 56px}
.upart .uc{font-weight:600;color:var(--ink)}

/* filters */
.filters{display:flex;flex-wrap:wrap;gap:7px;margin-bottom:16px}
.chip{font-size:12.5px;padding:6px 13px;border:1px solid var(--line);background:#fff;border-radius:20px;cursor:pointer;color:var(--ink)}
.chip.on{background:var(--green);color:#fff;border-color:var(--green)}

/* team grid */
.tgrid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-bottom:8px}
@media(min-width:681px){.tgrid{grid-template-columns:repeat(4,minmax(0,1fr))}}
.tcard{background:#fff;border:1px solid var(--line);border-radius:11px;padding:11px 13px;display:flex;align-items:center;gap:10px;color:var(--ink)}
.tcard:hover{border-color:var(--green);text-decoration:none;box-shadow:0 2px 8px rgba(0,0,0,.06)}
.uniicon{flex:0 0 24px;height:26px;display:flex;align-items:center;justify-content:center;line-height:0}
.tinfo{min-width:0;flex:1;display:block}
.tcard .tn{display:block;font-weight:700;font-size:14.5px;margin-bottom:5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.tcard .tags{display:flex;gap:5px;flex-wrap:wrap;min-width:0}
.tag{font-size:10.5px;padding:1px 7px;border-radius:5px;background:#eef0f5;color:var(--green-d);white-space:nowrap;max-width:100%;overflow:hidden;text-overflow:ellipsis}
.tag.cat{white-space:normal;overflow-wrap:anywhere}
.tag.ku-江戸川{background:#2f5c9e;color:#fff}
.tag.ku-葛飾{background:#2f8f5b;color:#fff}
.seclead{font-size:12.5px;color:var(--muted);margin-top:-4px}
/* チーム詳細: 主な戦績（年度＋大会名＋順位） */
.titles{display:flex;flex-direction:column;gap:6px;margin:4px 0 12px}
.til{display:flex;align-items:center;justify-content:space-between;gap:9px;background:#eef1f7;border:1px solid var(--line);border-radius:9px;padding:6px 12px;font-size:13px}
.til-name{color:var(--ink);min-width:0;flex:1}
.til-rank{font-weight:700;color:var(--green-d);flex:0 0 auto;white-space:nowrap}
.til.ti-1{background:#fff6db;border-color:#ecd98f}
.til.ti-1 .til-rank{color:#9a7400}
.til.ti-2{background:#eef2f6;border-color:#d3d9e2}
.til.ti-3{background:#f6efe6;border-color:#e2cfb4}
.til.ti-3 .til-rank{color:#8a6326}
/* チーム詳細: 出場した大会リンク */
.tourlinks{display:flex;flex-direction:column;gap:7px}
.tourlink{display:flex;align-items:center;justify-content:space-between;gap:10px;background:#fff;border:1px solid var(--line);border-radius:10px;padding:10px 13px;color:var(--ink)}
.tourlink:hover{border-color:var(--green);text-decoration:none;box-shadow:0 2px 8px rgba(0,0,0,.05)}
.tl-n{font-weight:600;font-size:13.5px;min-width:0}
.tl-y{display:inline-block;font-size:11px;font-weight:700;color:var(--muted);margin-right:6px}
.tl-r{flex:0 0 auto;font-size:12px;font-weight:700;color:var(--green-d);background:#eef1f7;border-radius:6px;padding:2px 9px;white-space:nowrap}
.tl-r.r1{background:#fff6db;color:#9a7400}
/* チーム詳細: 同区チームのチップ */
.chips-teams{display:flex;flex-wrap:wrap;gap:6px}
.chip-team{font-size:12.5px;padding:5px 11px;border:1px solid var(--line);border-radius:18px;background:#fff;color:var(--green-d)}
.chip-team:hover{border-color:var(--green);text-decoration:none}
.tag.grp{background:#fff4e0;color:#b07400}
.tag.cat{background:#eef0f5;color:var(--green-d)}

/* table */
table.std{width:100%;border-collapse:collapse;background:#fff;border-radius:10px;overflow:hidden;font-size:13.5px;margin-bottom:8px}
table.std th{background:var(--green);color:#fff;font-weight:600;padding:7px 6px;font-size:12px}
table.std td{padding:7px 6px;border-top:1px solid var(--line);text-align:center;font-variant-numeric:tabular-nums}
table.std td.tn{text-align:left;font-weight:700}
table.std tr.top td{background:#eef1f7}
.grp-title{font-weight:800;font-size:15px;margin:20px 0 8px;color:var(--green-d)}
.grp-title.anchor{scroll-margin-top:108px}
.sec.anchor{scroll-margin-top:108px}
.anchornav{display:flex;flex-wrap:wrap;gap:7px;margin:6px 0 18px}
.anchorlink{font-size:12.5px;font-weight:600;padding:6px 12px;border:1px solid var(--line);border-radius:20px;background:#fff;color:var(--green-d)}
.anchorlink:hover{border-color:var(--green);text-decoration:none}
.dscope{font-size:10.5px;font-weight:700;color:#8a5a00;background:#fff5e0;border:1px solid #e6cf94;border-radius:4px;padding:1px 6px;white-space:nowrap}
/* 区大会用 2段アイコン（上：区名／下：学年。区ごとに色分け） */
.kutag{display:inline-flex;flex-direction:column;align-items:stretch;justify-content:center;min-width:54px;border-radius:7px;color:#fff;line-height:1.15;margin-right:8px;overflow:hidden;vertical-align:middle;flex:0 0 auto;text-align:center}
.kutag .kt-top{font-size:9.5px;font-weight:700;padding:2px 6px 1px}
.kutag .kt-bot{font-size:13px;font-weight:800;padding:0 6px 2px}
.kutag.ku-edo{background:#2f5c9e}
.kutag.ku-katsu{background:#2f8f5b}

/* team detail */
.profile{background:#fff;border:1px solid var(--line);border-radius:12px;padding:16px;margin-bottom:18px}
.profile h1{font-size:22px;margin:0 0 4px}
.profile .slo{color:var(--green-d);font-weight:600;margin:0 0 14px}
.kv{display:grid;grid-template-columns:90px 1fr;gap:6px 12px;font-size:14px}
.kv dt{color:var(--muted)}
.kv dd{margin:0}
.btns{display:flex;gap:9px;margin:16px 0 0}
.btn{flex:1;text-align:center;padding:11px;border-radius:9px;font-weight:700;font-size:13.5px;color:#fff}
.btn.hp{background:var(--green)}
.btn.ig{background:#c13584}
.btn.dis{background:#cfd6d0;pointer-events:none}
.btn:hover{text-decoration:none;opacity:.92}

/* flow diagram */
.flow{background:#fff;border:1px solid var(--line);border-radius:12px;padding:16px;font-size:13.5px;line-height:1.9}
.flow b{color:var(--green-d)}
.note{background:#fff8e6;border:1px solid #f0e2b8;border-radius:9px;padding:11px 14px;font-size:12.5px;color:#7a6420;margin:14px 0}

/* チーム年度別成績タブ */
.ytabs{display:flex;gap:7px;flex-wrap:wrap;margin-bottom:12px}
.ytab{font-size:13px;font-weight:700;padding:7px 15px;border:1px solid var(--line);border-radius:20px;background:#fff;color:var(--ink);cursor:pointer;font-family:inherit}
.ytab:hover{border-color:var(--green)}
.ytab.on{background:var(--green);color:#fff;border-color:var(--green)}
.recsum{background:var(--card);border:1px solid var(--line);border-radius:10px;padding:11px 14px;font-size:13.5px;margin-bottom:12px}
.recsum b{font-size:15px;color:var(--green-d)}

/* 世代の歩み（コホート・ラダー）*/
.cohort{background:var(--card);border:1px solid var(--line);border-radius:11px;padding:12px 14px;margin-bottom:12px}
.cohort-h{font-weight:800;font-size:14px;color:var(--green-d);margin-bottom:9px}
.cstep{display:grid;grid-template-columns:46px 1fr auto;gap:9px;align-items:center;padding:6px 0;border-top:1px solid var(--line);font-size:13px}
.cstep:first-of-type{border-top:none}
.cstep .cg{font-weight:700}
.cstep .ct{color:var(--muted);min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.cstep .cr{font-weight:700;white-space:nowrap}
.cstep.empty{opacity:.45}

/* 区大会インデックス */
.distcols{display:grid;grid-template-columns:1fr 1fr;gap:10px 22px;align-items:start}
@media(max-width:680px){.distcols{grid-template-columns:1fr}}
.distcol h2.sec{margin-top:8px}
.distcol.anchor{scroll-margin-top:108px}
.dyear{font-weight:800;font-size:13px;color:var(--green-d);margin:14px 0 7px}
.distrow{display:flex;align-items:center;gap:11px;background:#fff;border:1px solid var(--line);border-radius:10px;padding:8px 13px;margin-bottom:8px;color:var(--ink);height:88px;overflow:hidden}
.distrow:hover{border-color:var(--green);text-decoration:none;box-shadow:0 2px 8px rgba(0,0,0,.05)}
.distrow .dgrade{flex:0 0 42px;align-self:center;height:42px;border-radius:9px;background:var(--green);color:#fff;font-weight:800;font-size:13px;display:flex;align-items:center;justify-content:center;text-align:center;line-height:1.1;white-space:nowrap}
.distrow .dbody{flex:1;min-width:0;display:flex;flex-direction:column;justify-content:center;gap:3px}
.distrow .dname{font-weight:700;font-size:14px;line-height:1.3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.distrow .dname.sm{font-size:12.5px}
.distrow .dname.xs{font-size:11px}
.distrow .dmeta{font-size:11.5px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.distrow .dchamp{display:block;font-size:12.5px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-height:16px}
.distrow .dchamp.sm{font-size:11px}
.distrow .dright{flex:0 0 auto;display:flex;flex-direction:column;align-items:flex-end;justify-content:center;gap:6px;text-align:right}
.distrow .dpdf{font-size:11px;color:var(--blue);font-weight:700;white-space:nowrap}
.distrow .dpdf.res{color:var(--green-d)}

/* 年度バー */
.seasonbar{display:flex;align-items:center;gap:9px;margin:2px 0 12px}
.seasontag{background:var(--green);color:#fff;font-weight:800;font-size:14px;padding:4px 13px;border-radius:20px}
.seasonnote{font-size:12px;color:var(--muted)}
.yearsw{display:flex;gap:7px;flex-wrap:wrap;margin-bottom:14px}
.ychip{font-size:13px;font-weight:700;padding:7px 15px;border:1px solid var(--line);border-radius:20px;background:#fff;color:var(--ink)}
.ychip:hover{border-color:var(--green);text-decoration:none}
.ychip.on{background:var(--green);color:#fff;border-color:var(--green)}

/* 大会一覧（学年を大きく表示）*/
.tourlist{display:flex;flex-direction:column;gap:11px}
.tourcard{display:flex;align-items:center;gap:14px;background:#fff;border:1px solid var(--line);border-radius:12px;padding:12px 14px;color:var(--ink)}
.tourcard:hover{border-color:var(--green);box-shadow:0 2px 8px rgba(0,0,0,.06);text-decoration:none}
.tourcard.disabled{opacity:.72}
.gradebox{flex:0 0 56px;height:56px;border-radius:12px;text-align:center;line-height:56px;color:#fff;font-weight:800;font-size:25px}
.gradebox small{font-size:13px;font-weight:700;margin-left:1px}
.gradebox.g-3{background:#1b7a3d}
.gradebox.g-4{background:#1769aa}
.gradebox.g-5{background:#c77d00}
.gradebox.g-6{background:#b0306a}
/* HOME等：日付前の学年アイコン（横表記） */
.gtag{display:inline-flex;align-items:center;justify-content:center;min-width:30px;height:21px;padding:0 6px;border-radius:6px;background:var(--muted);color:#fff;font-weight:800;font-size:12px;line-height:1;vertical-align:middle;margin-right:7px}
.gtag.g-3{background:#1b7a3d}.gtag.g-4{background:#1769aa}.gtag.g-5{background:#c77d00}.gtag.g-6{background:#b0306a}
.updated{font-size:11.5px;color:var(--muted);text-align:right;margin:-2px 0 12px;font-variant-numeric:tabular-nums}
.morebtn{display:block;width:100%;padding:11px;margin:2px 0 10px;background:#fff;border:1px solid var(--line);border-radius:10px;color:var(--green-d);font-weight:700;font-size:13.5px;cursor:pointer}
.morebtn:hover{border-color:var(--green);background:#f5f6f9}
.tourbody{flex:1;min-width:0}
.tourname{font-weight:700;font-size:15px;line-height:1.4}
.tourmeta{display:flex;align-items:center;gap:8px;margin-top:6px;font-size:13px;flex-wrap:wrap}
.tdate{font-size:12px;color:var(--muted);font-variant-numeric:tabular-nums}
.ddate{font-size:11.5px;color:var(--muted);white-space:nowrap;font-variant-numeric:tabular-nums}
.chev{flex:0 0 auto;color:var(--gray);font-size:24px;font-weight:700}

/* トーナメント表 */
.champ{background:#fff8e6;border:1px solid #f0e2b8;border-radius:10px;padding:13px 16px;font-size:15px;margin-bottom:14px;color:#7a6420}
.bnote{font-size:11px;color:var(--gray);text-align:center;margin-bottom:6px}
.bracket{display:flex;overflow-x:auto;padding:8px 2px 18px;-webkit-overflow-scrolling:touch}
.round{display:flex;flex-direction:column;flex:0 0 158px}
.rtitle{flex:0 0 auto;text-align:center;font-weight:700;font-size:12.5px;color:var(--green-d);padding:6px 0;background:#eef1f7;border-radius:7px;margin:0 10px 10px}
.ties{flex:1;display:flex;flex-direction:column;justify-content:space-around}
.tie{flex:1;display:flex;align-items:center;position:relative}
.box{background:#fff;border:1px solid var(--line);border-radius:9px;width:100%;margin:6px 10px;position:relative}
.seat{display:flex;align-items:center;gap:6px;padding:6px 9px;font-size:13px}
.seat+.seat{border-top:1px solid var(--line)}
.seat .nmwrap{flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.seat .nm{font-weight:700}
.seat .nm.tbd{color:var(--gray);font-weight:400}
.seat .pt{font-variant-numeric:tabular-nums;font-weight:800;min-width:16px;text-align:center}
.seat.win{background:#eef1f7}
.seat.win .nm{color:var(--green-d)}
.seat.win .pt{color:var(--green)}
.pkmini{font-size:10.5px;color:var(--red);text-align:center;padding:2px 0;border-top:1px dashed var(--line)}
/* 接続線 */
.round:not(:last-child) .box::after{content:"";position:absolute;right:-10px;top:50%;width:10px;height:2px;background:var(--line)}
.round:not(:first-child) .box::before{content:"";position:absolute;left:-10px;top:50%;width:10px;height:2px;background:var(--line)}
.round:not(:last-child) .tie:nth-child(odd)::after{content:"";position:absolute;right:0;top:50%;height:100%;width:2px;background:var(--line)}
/* 大規模ブラケット：接続線オフの列表示 */
.bracket.flat .box::after,.bracket.flat .box::before,.bracket.flat .tie:nth-child(odd)::after{display:none}
.bracket.flat .round{flex:0 0 150px}
.bracket.flat .ties{justify-content:flex-start;gap:8px}
.bracket.flat .tie{flex:0 0 auto}
.partlist{font-size:13px;line-height:1.9;color:var(--ink)}

footer.site{border-top:1px solid var(--line);padding:22px 0;color:var(--muted);font-size:12px;text-align:center}
.updated{font-size:11px;color:var(--gray);text-align:right;margin-bottom:8px}
