/* =========================================================
   中京大学硬式庭球部 公式HP — Design System
   赤主役 / ネイビー暗部 / 青アクセント
   ========================================================= */

:root{
  --red:#CE0E2D;
  --red-700:#A50B24;
  --red-900:#73061A;
  --navy:#0B1A36;
  --navy-2:#0E2244;
  --blue:#1748C4;
  --blue-light:#3D6FE8;
  --ink:#12161D;
  --paper:#FFFFFF;
  --mist:#F2F3F5;
  --mist-2:#E8EAEE;
  --line:#E0E2E8;
  --line-dark:rgba(255,255,255,.14);
  --muted:#6A7180;
  --muted-on-dark:#9FB0C9;

  --maxw:1320px;
  --gutter:clamp(18px,4vw,48px);

  --ff-jp:"Noto Sans JP",sans-serif;
  --ff-label:"Oswald",sans-serif;
  --ff-display:"Anton","Oswald",sans-serif;

  --skew:-9deg;
  --ease:cubic-bezier(.22,.61,.36,1);

  /* 部旗トリコロール（赤・白・青）— チームアイデンティティ */
  --flag-h:linear-gradient(180deg,var(--red) 0 38%,#fff 38% 62%,var(--blue) 62% 100%);
  --flag-v:linear-gradient(90deg,var(--red) 0 38%,#fff 38% 62%,var(--blue) 62% 100%);
}

*{box-sizing:border-box;}
html{-webkit-text-size-adjust:100%;}
body{
  margin:0;
  font-family:var(--ff-jp);
  color:var(--ink);
  background:var(--paper);
  font-weight:500;
  line-height:1.7;
  letter-spacing:.01em;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
button{font-family:inherit;cursor:pointer;}
::selection{background:var(--red);color:#fff;}

.container{
  width:100%;
  max-width:var(--maxw);
  margin-inline:auto;
  padding-inline:var(--gutter);
}

/* ---------- English label / Oswald helpers ---------- */
.en{
  font-family:var(--ff-label);
  font-weight:600;
  letter-spacing:.16em;
  text-transform:uppercase;
}
.en-display{
  font-family:var(--ff-display);
  font-weight:400;
  letter-spacing:.01em;
  line-height:.92;
  text-transform:uppercase;
}

/* ---------- Placeholder image ---------- */
.ph{
  position:relative;
  background:
    repeating-linear-gradient(135deg,#d7dae1 0 2px,transparent 2px 12px),
    linear-gradient(135deg,#eceef2,#dfe2e8);
  display:flex;align-items:center;justify-content:center;
  overflow:hidden;
}
.ph::after{
  content:attr(data-label);
  font-family:"Oswald",monospace;
  font-size:11px;letter-spacing:.22em;text-transform:uppercase;
  color:#9298a6;
  background:rgba(255,255,255,.72);
  padding:5px 12px;border:1px solid rgba(0,0,0,.08);
  white-space:nowrap;
}
.ph.dark{
  background:
    repeating-linear-gradient(135deg,rgba(255,255,255,.05) 0 2px,transparent 2px 12px),
    linear-gradient(135deg,#16263f,#0b1a30);
}
.ph.dark::after{color:#7f8ca3;background:rgba(7,16,30,.55);border-color:rgba(255,255,255,.12);}

/* ---------- 実写画像（プレースホルダー差替） ---------- */
.ph.has-img{background:var(--navy);}
.ph.has-img::after{display:none;}
.ph.has-img picture{display:contents;}
.ph.has-img img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;}
.ph.pos-left img{object-position:18% center;}
.ph.pos-center img{object-position:center 28%;}
.ph.pos-right img{object-position:82% center;}

/* ---------- Tag (skewed) ---------- */
.tag{
  display:inline-flex;align-items:center;gap:.5em;
  font-family:var(--ff-label);font-weight:600;
  font-size:12px;letter-spacing:.14em;text-transform:uppercase;
  color:#fff;background:var(--red);
  padding:6px 14px;
  transform:skewX(var(--skew));
}
.tag > *{transform:skewX(calc(-1 * var(--skew)));}
.tag.blue{background:var(--blue);}
.tag.navy{background:var(--navy);}
.tag.ghost{background:transparent;color:var(--red);box-shadow:inset 0 0 0 2px var(--red);}

/* ---------- Buttons ---------- */
.btn{
  --bg:var(--red);--fg:#fff;
  position:relative;display:inline-flex;align-items:center;gap:.7em;
  font-family:var(--ff-label);font-weight:600;
  font-size:14px;letter-spacing:.12em;text-transform:uppercase;
  color:var(--fg);background:var(--bg);
  padding:15px 26px;
  transform:skewX(var(--skew));
  transition:transform .25s var(--ease),background .2s,color .2s;
  white-space:nowrap;
}
.btn > *{display:inline-flex;align-items:center;gap:.6em;transform:skewX(calc(-1 * var(--skew)));}
.btn:hover{transform:skewX(var(--skew)) translateX(3px);background:var(--red-700);}
.btn .arw{font-family:var(--ff-jp);font-weight:700;}
.btn--blue{--bg:var(--blue);}
.btn--blue:hover{background:#123a9e;}
.btn--ink{--bg:var(--ink);}
.btn--ink:hover{background:#000;}
.btn--outline{--bg:transparent;--fg:var(--ink);box-shadow:inset 0 0 0 2px currentColor;}
.btn--outline:hover{background:var(--ink);--fg:#fff;}
.btn--ghost-light{--bg:transparent;--fg:#fff;box-shadow:inset 0 0 0 2px rgba(255,255,255,.5);}
.btn--ghost-light:hover{background:#fff;--fg:var(--ink);}
.btn.sm{padding:11px 18px;font-size:12px;}

/* ---------- Section heading ---------- */
.section{padding-block:clamp(56px,8vw,108px);}
.section.tight{padding-block:clamp(40px,6vw,76px);}
.sec-head{
  display:flex;align-items:flex-end;justify-content:space-between;
  gap:24px;flex-wrap:wrap;margin-bottom:38px;
}
.sec-head .lead{display:flex;align-items:center;gap:18px;position:relative;padding-left:22px;}
.sec-head .lead::before{content:"";position:absolute;left:0;top:50%;
  transform:translateY(-50%) skewX(var(--skew));
  width:8px;height:62%;background:var(--flag-h);}
.sec-index{
  font-family:var(--ff-display);font-size:clamp(34px,5vw,58px);
  color:var(--red);line-height:.8;
}
.sec-titles .en-sub{
  font-family:var(--ff-label);font-weight:600;font-size:13px;
  letter-spacing:.26em;text-transform:uppercase;color:var(--red);
  display:block;margin-bottom:4px;
}
.sec-titles h2{
  margin:0;font-weight:900;line-height:1.05;letter-spacing:.01em;
  font-size:clamp(26px,3.6vw,42px);white-space:nowrap;
}
.sec-head.on-dark .sec-titles h2{color:#fff;}
.sec-head.on-dark .sec-index,.sec-head.on-dark .en-sub{color:#fff;}
.sec-head.on-dark .sec-index{color:var(--red);}

.divider-top{height:6px;background:var(--flag-h);}

/* =========================================================
   部旗トリコロール リボン（最上部）
   ========================================================= */
.flagbar{height:8px;width:100%;
  background:linear-gradient(90deg,
    var(--red) 0 33.33%,#fff 33.33% 66.66%,var(--blue) 66.66% 100%);}

/* =========================================================
   TOP UTILITY BAR
   ========================================================= */
.util{
  background:var(--ink);color:#cfd3da;
  font-size:12px;
}
.util .container{display:flex;align-items:center;justify-content:space-between;height:38px;}
.util .u-left{display:flex;align-items:center;gap:18px;}
.util .u-left .badge{font-family:var(--ff-label);font-weight:600;letter-spacing:.18em;color:#fff;text-transform:uppercase;}
.util .u-left .div{width:1px;height:14px;background:rgba(255,255,255,.2);}
.util a:hover{color:#fff;}
.util .u-right{display:flex;align-items:center;gap:16px;}
.util .socials{display:flex;gap:12px;}
.util .socials a{font-family:var(--ff-label);font-weight:600;letter-spacing:.1em;font-size:11px;}

/* =========================================================
   HEADER / NAV
   ========================================================= */
.site-header{position:sticky;top:0;z-index:60;background:var(--paper);
  box-shadow:0 1px 0 var(--line);transition:box-shadow .2s;}
.site-header.scrolled{box-shadow:0 6px 24px rgba(15,23,42,.12);}
.nav{display:flex;align-items:center;gap:28px;height:74px;}
.brand{display:flex;align-items:center;gap:14px;margin-right:auto;}
.brand .mark{
  width:46px;height:46px;flex:none;position:relative;
  background:var(--red);transform:skewX(var(--skew));
  display:flex;align-items:center;justify-content:center;
}
.brand .mark span{transform:skewX(calc(-1 * var(--skew)));
  font-family:var(--ff-display);color:#fff;font-size:26px;line-height:1;}
.brand .mark::after{content:"";position:absolute;right:-6px;bottom:-6px;width:14px;height:14px;background:var(--flag-h);}
.brand .wd{display:flex;flex-direction:column;line-height:1;}
.brand .wd .jp{font-weight:900;font-size:16px;letter-spacing:.02em;}
.brand .wd .en{font-family:var(--ff-label);font-weight:500;font-size:10px;letter-spacing:.22em;color:var(--muted);margin-top:4px;}

.nav-links{display:flex;align-items:center;gap:4px;height:100%;}
.nav-links a{
  display:flex;flex-direction:column;justify-content:center;gap:2px;
  padding:0 14px;height:100%;font-weight:700;font-size:14px;position:relative;
}
.nav-links a .nl-en{font-family:var(--ff-label);font-weight:500;font-size:9px;letter-spacing:.18em;color:var(--muted);text-transform:uppercase;}
.nav-links a::before{content:"";position:absolute;left:14px;right:14px;bottom:0;height:4px;background:var(--red);transform:scaleX(0);transform-origin:left;transition:transform .25s var(--ease);}
.nav-links a:hover::before,.nav-links a.active::before{transform:scaleX(1);}
.nav-cta{display:flex;align-items:center;gap:10px;}
.nav-toggle{display:none;width:46px;height:46px;border:none;background:var(--ink);color:#fff;flex-direction:column;gap:5px;align-items:center;justify-content:center;}
.nav-toggle span{width:22px;height:2px;background:#fff;transition:.25s;}

/* mobile drawer */
.drawer{position:fixed;inset:0;z-index:80;display:none;}
.drawer.open{display:block;}
.drawer .scrim{position:absolute;inset:0;background:rgba(8,12,20,.6);}
.drawer .panel{position:absolute;top:0;right:0;bottom:0;width:min(86vw,380px);background:var(--ink);color:#fff;padding:24px;display:flex;flex-direction:column;gap:6px;transform:translateX(100%);transition:transform .3s var(--ease);overflow:auto;}
.drawer.open .panel{transform:none;}
.drawer .panel .d-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px;}
.drawer .panel .d-close{background:none;border:none;color:#fff;font-size:26px;line-height:1;}
.drawer .panel a{padding:15px 6px;border-bottom:1px solid var(--line-dark);font-weight:700;font-size:18px;display:flex;justify-content:space-between;align-items:center;}
.drawer .panel a .nl-en{font-family:var(--ff-label);font-weight:500;font-size:11px;letter-spacing:.16em;color:var(--muted-on-dark);}

/* =========================================================
   HERO
   ========================================================= */
.hero{position:relative;background:var(--navy);color:#fff;overflow:hidden;}
.hero-stage{position:relative;height:clamp(520px,82vh,860px);}
.hero-slide{position:absolute;inset:0;opacity:0;transition:opacity .9s var(--ease);pointer-events:none;}
.hero-slide.active{opacity:1;pointer-events:auto;}
.hero-slide .ph{position:absolute;inset:0;}
.hero-slide .ph::before{content:"";position:absolute;inset:0;z-index:1;
  background:
    linear-gradient(90deg,rgba(8,16,32,.92) 0%,rgba(8,16,32,.6) 42%,rgba(8,16,32,.15) 75%,rgba(8,16,32,.45) 100%),
    linear-gradient(0deg,rgba(8,16,32,.85) 0%,transparent 46%);}
.hero-inner{position:relative;z-index:3;height:100%;display:flex;flex-direction:column;justify-content:flex-end;padding-bottom:clamp(120px,16vh,180px);}
.hero-kicker{display:flex;align-items:center;gap:14px;margin-bottom:22px;}
.hero-kicker .line{width:58px;height:4px;background:var(--flag-v);}
.hero-kicker .en{font-size:13px;letter-spacing:.28em;color:#fff;}
.hero h1{
  margin:0;font-weight:900;letter-spacing:.01em;line-height:1.02;
  font-size:clamp(40px,7.2vw,104px);
  text-shadow:0 4px 40px rgba(0,0,0,.35);
}
.hero h1 .accent{color:var(--red);
  text-shadow:0 0 0 transparent;
  -webkit-text-stroke:0;}
.hero .sub{margin-top:22px;font-size:clamp(15px,1.5vw,19px);font-weight:600;max-width:40ch;color:#e7ecf4;}
.hero .hero-cta{display:flex;gap:14px;margin-top:34px;flex-wrap:wrap;}

/* diagonal tricolor band（部旗） */
.hero::before{content:"";position:absolute;left:-3%;bottom:0;z-index:2;
  width:56%;height:18px;background:var(--flag-v);
  transform:skewX(var(--skew));transform-origin:bottom left;}
.hero-side{position:absolute;right:0;top:0;bottom:0;z-index:3;width:68px;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:20px;
  border-left:1px solid var(--line-dark);}
/* 右レールの縦三色ストライプ（部旗の縦帯） */
.hero-side::before{content:"";position:absolute;left:-1px;top:20%;bottom:20%;width:7px;
  background:var(--flag-h);}
.hero-side .vert{writing-mode:vertical-rl;font-family:var(--ff-label);font-weight:600;letter-spacing:.3em;font-size:12px;color:var(--muted-on-dark);text-transform:uppercase;}

/* hero controls */
.hero-controls{position:absolute;left:0;right:0;bottom:0;z-index:5;}
.hero-controls .container{display:flex;align-items:center;gap:22px;padding-block:18px;}
.hero-dots{display:flex;gap:10px;}
.hero-dots button{width:34px;height:4px;background:rgba(255,255,255,.3);border:none;padding:0;transition:.3s;}
.hero-dots button.on{background:var(--red);width:54px;}
.hero-arrows{display:flex;gap:8px;margin-left:auto;}
.hero-arrows button{width:46px;height:46px;border:1px solid var(--line-dark);background:rgba(255,255,255,.04);color:#fff;font-size:18px;display:flex;align-items:center;justify-content:center;transition:.2s;}
.hero-arrows button:hover{background:var(--red);border-color:var(--red);}
.hero-count{font-family:var(--ff-label);font-weight:600;letter-spacing:.14em;font-size:13px;color:var(--muted-on-dark);}
.hero-count b{color:#fff;}

/* =========================================================
   MATCH BAR (次戦 / 結果 / 順位)
   ========================================================= */
.matchbar{background:var(--ink);color:#fff;position:relative;z-index:4;}
.matchbar .grid{display:grid;grid-template-columns:1.5fr 1.45fr 1.05fr;}
.matchbar .cell{padding:30px clamp(20px,3vw,40px);border-right:1px solid var(--line-dark);}
.matchbar .cell:last-child{border-right:none;}
.mb-label{display:flex;align-items:center;gap:10px;margin-bottom:16px;}
.mb-label .en{font-size:12px;letter-spacing:.16em;color:var(--muted-on-dark);white-space:nowrap;}
.mb-label .dot{width:8px;height:8px;background:var(--red);transform:skewX(var(--skew));}

.next-match .nm-league{font-family:var(--ff-label);font-weight:600;letter-spacing:.06em;color:var(--blue-light);font-size:13px;margin-bottom:10px;text-transform:uppercase;}
.next-match .nm-teams{display:flex;align-items:center;gap:16px;}
.next-match .nm-team{display:flex;align-items:center;gap:11px;font-weight:900;font-size:clamp(15px,1.4vw,19px);white-space:nowrap;}
.next-match .nm-team .badge{width:38px;height:38px;flex:none;}
.next-match .vs{font-family:var(--ff-display);font-size:22px;color:var(--red);}
.next-match .nm-meta{margin-top:14px;display:flex;gap:8px 18px;flex-wrap:wrap;color:var(--muted-on-dark);font-size:13px;font-weight:600;}
.next-match .nm-meta span{white-space:nowrap;}
.next-match .nm-meta b{color:#fff;}

.countdown{display:flex;gap:10px;margin-top:18px;}
.cd-unit{background:var(--navy-2);min-width:58px;text-align:center;padding:8px 6px;transform:skewX(var(--skew));}
.cd-unit > div{transform:skewX(calc(-1 * var(--skew)));}
.cd-unit .num{font-family:var(--ff-display);font-size:28px;line-height:1;color:#fff;}
.cd-unit .lab{font-family:var(--ff-label);font-size:10px;letter-spacing:.14em;color:var(--muted-on-dark);margin-top:4px;text-transform:uppercase;}

.results .res{display:flex;align-items:center;gap:14px;padding:9px 0;border-bottom:1px solid var(--line-dark);}
.results .res:last-child{border-bottom:none;}
.results .res .rdate{font-family:var(--ff-label);font-size:12px;color:var(--muted-on-dark);width:54px;flex:none;letter-spacing:.06em;}
.results .res .ropp{font-weight:700;font-size:14px;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.results .res .rscore{font-family:var(--ff-display);font-size:18px;flex:none;white-space:nowrap;letter-spacing:.02em;}
.results .res .wl{font-family:var(--ff-label);font-weight:600;font-size:11px;letter-spacing:.1em;padding:3px 8px;color:#fff;flex:none;white-space:nowrap;}
.results .res .wl.w{background:var(--red);}
.results .res .wl.l{background:#3a4254;}

.standings .st-pos{display:flex;align-items:baseline;gap:10px;margin-bottom:8px;}
.standings .st-pos .big{font-family:var(--ff-display);font-size:46px;color:var(--red);line-height:.8;}
.standings .st-pos .of{color:var(--muted-on-dark);font-weight:600;font-size:13px;white-space:nowrap;}
.standings .st-league{font-weight:700;font-size:15px;margin-bottom:14px;}
.standings .st-row{display:flex;justify-content:space-between;gap:10px;font-size:13px;padding:6px 0;border-bottom:1px solid var(--line-dark);color:var(--muted-on-dark);white-space:nowrap;}
.standings .st-row b{color:#fff;font-family:var(--ff-label);letter-spacing:.06em;}

/* =========================================================
   NEWS
   ========================================================= */
.news-tabs{display:flex;gap:8px;flex-wrap:wrap;}
.news-tabs button{
  font-family:var(--ff-label);font-weight:600;font-size:12px;letter-spacing:.12em;text-transform:uppercase;
  padding:9px 16px;background:var(--mist);color:var(--ink);border:none;transform:skewX(var(--skew));transition:.2s;}
.news-tabs button > span{display:inline-block;transform:skewX(calc(-1 * var(--skew)));}
.news-tabs button.on{background:var(--red);color:#fff;}
.news-tabs button:hover{background:var(--ink);color:#fff;}
.news-tabs button.on:hover{background:var(--red);}

.news-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr;gap:2px;background:var(--line);border:1px solid var(--line);margin-top:30px;}
.news-card{background:#fff;display:flex;flex-direction:column;transition:.25s;position:relative;}
.news-card .nc-media{position:relative;aspect-ratio:16/10;}
.news-card .nc-media > .ph{position:absolute;inset:0;}
.news-card.feature{grid-row:span 2;}
.news-card.feature .nc-media{aspect-ratio:16/11;}
.news-card .nc-cat{position:absolute;left:0;top:0;z-index:2;}
.news-card .nc-cat .tag{font-size:11px;padding:6px 12px;transform:none;}
.news-card .nc-body{padding:20px 22px 24px;display:flex;flex-direction:column;gap:10px;flex:1;}
.news-card .nc-meta{display:flex;align-items:center;gap:12px;font-family:var(--ff-label);font-size:12px;letter-spacing:.06em;color:var(--muted);}
.news-card .nc-meta .cat{color:var(--red);font-weight:600;letter-spacing:.1em;}
.news-card .nc-meta .cat::after{content:"";display:inline-block;width:1px;height:11px;background:var(--line);margin-left:12px;vertical-align:-1px;}
.news-card h3{margin:0;font-weight:900;line-height:1.4;font-size:16px;}
.news-card.feature h3{font-size:clamp(20px,2.2vw,28px);}
.news-card .nc-ex{color:var(--muted);font-size:13px;font-weight:500;margin:0;display:none;}
.news-card.feature .nc-ex{display:block;}
.news-card .nc-more{margin-top:auto;font-family:var(--ff-label);font-weight:600;font-size:12px;letter-spacing:.12em;color:var(--ink);display:flex;align-items:center;gap:8px;text-transform:uppercase;}
.news-card .nc-more .arw{color:var(--red);transition:transform .2s;}
.news-card:hover{z-index:2;box-shadow:0 16px 40px rgba(15,23,42,.14);}
.news-card:hover .nc-more .arw{transform:translateX(5px);}
.news-card .nc-bar{height:5px;background:var(--red);transform:scaleX(0);transform-origin:left;transition:transform .25s var(--ease);}
.news-card:hover .nc-bar{transform:scaleX(1);}
.news-foot{display:flex;justify-content:center;margin-top:36px;}

/* =========================================================
   HONORS / STATS BAND
   ========================================================= */
.honors{background:var(--navy);color:#fff;position:relative;overflow:hidden;}
.honors::before{content:"";position:absolute;inset:0;background:
  repeating-linear-gradient(115deg,rgba(255,255,255,.025) 0 1px,transparent 1px 60px);}
.honors .container{position:relative;}
.honors .h-head{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;flex-wrap:wrap;margin-bottom:44px;}
.honors .h-head .en-sub{font-family:var(--ff-label);font-weight:600;letter-spacing:.26em;color:var(--red);font-size:13px;display:block;margin-bottom:8px;text-transform:uppercase;}
.honors .h-head h2{margin:0;font-weight:900;font-size:clamp(26px,3.6vw,42px);line-height:1.05;}
.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line-dark);}
.stat{background:var(--navy);padding:30px clamp(16px,2vw,28px);position:relative;}
.stat .num{font-family:var(--ff-display);font-size:clamp(48px,6vw,78px);line-height:.82;color:#fff;}
.stat .num .u{font-size:.4em;color:var(--red);margin-left:4px;}
.stat .lab{margin-top:12px;font-weight:700;font-size:14px;}
.stat .en{margin-top:4px;font-family:var(--ff-label);font-weight:500;font-size:11px;letter-spacing:.16em;color:var(--muted-on-dark);text-transform:uppercase;}
.stat::before{content:"";position:absolute;left:0;top:30px;width:4px;height:34px;background:var(--red);}

/* =========================================================
   SQUAD
   ========================================================= */
.squad{background:var(--mist);}
.squad-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;}
.player{background:#fff;position:relative;overflow:hidden;transition:.25s;}
.player .p-media{position:relative;aspect-ratio:3/4;}
.player .p-media > .ph{position:absolute;inset:0;}
.player .p-num{position:absolute;right:14px;top:10px;z-index:2;font-family:var(--ff-display);font-size:54px;color:#fff;opacity:.85;line-height:.8;text-shadow:0 2px 18px rgba(0,0,0,.4);}
.player .p-role{position:absolute;left:0;bottom:0;z-index:2;}
.player .p-role .tag{transform:none;font-size:11px;}
.player .p-body{padding:16px 18px 20px;}
.player .p-body .yr{font-family:var(--ff-label);font-weight:600;font-size:11px;letter-spacing:.1em;color:var(--red);text-transform:uppercase;}
.player .p-body .nm{font-weight:900;font-size:19px;margin:4px 0 2px;}
.player .p-body .nm-en{font-family:var(--ff-label);font-weight:500;font-size:11px;letter-spacing:.14em;color:var(--muted);text-transform:uppercase;}
.player .p-body .pos{margin-top:10px;font-size:12px;font-weight:700;color:var(--muted);display:flex;align-items:center;gap:8px;}
.player .p-body .pos::before{content:"";width:7px;height:7px;background:var(--blue);}
.player:hover{transform:translateY(-4px);box-shadow:0 18px 40px rgba(15,23,42,.16);}
.player .p-accent{position:absolute;left:0;top:0;height:6px;width:100%;background:var(--flag-v);transform:scaleX(0);transform-origin:left;transition:transform .25s var(--ease);z-index:3;}
.player:hover .p-accent{transform:scaleX(1);}

/* =========================================================
   ABOUT / 理念
   ========================================================= */
.about{background:var(--paper);}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(30px,5vw,70px);align-items:center;}
.about-media{position:relative;}
.about-media .ph{aspect-ratio:4/5;}
.about-media .badge-est{position:absolute;left:-18px;bottom:-18px;background:var(--red);color:#fff;padding:20px 26px;transform:skewX(var(--skew));}
.about-media .badge-est > div{transform:skewX(calc(-1 * var(--skew)));}
.about-media .badge-est .est{font-family:var(--ff-label);font-weight:600;font-size:11px;letter-spacing:.2em;text-transform:uppercase;}
.about-media .badge-est .yr{font-family:var(--ff-display);font-size:44px;line-height:.9;}
.about-copy .en-sub{font-family:var(--ff-label);font-weight:600;letter-spacing:.26em;color:var(--red);font-size:13px;text-transform:uppercase;display:block;margin-bottom:14px;}
.about-copy h2{margin:0 0 8px;font-weight:900;font-size:clamp(26px,3.4vw,44px);line-height:1.18;}
.about-copy .creed{font-family:var(--ff-display);font-size:clamp(28px,3.6vw,46px);color:var(--red);letter-spacing:.04em;margin:18px 0;line-height:1;}
.about-copy p{color:#3a4150;font-size:15px;margin:0 0 16px;max-width:48ch;}
.about-facts{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:26px;border-top:2px solid var(--ink);padding-top:22px;}
.about-facts .f .k{font-family:var(--ff-label);font-weight:600;font-size:11px;letter-spacing:.14em;color:var(--muted);text-transform:uppercase;}
.about-facts .f .v{font-weight:900;font-size:18px;margin-top:4px;}

/* =========================================================
   JOIN / 新歓 CTA
   ========================================================= */
.join{position:relative;background:var(--red);color:#fff;overflow:hidden;}
.join .ph{position:absolute;inset:0;z-index:0;}
.join-veil{position:absolute;inset:0;z-index:1;background:linear-gradient(90deg,var(--red) 0%,rgba(206,14,45,.94) 46%,rgba(206,14,45,.66) 100%);}
.join .container{position:relative;z-index:2;display:grid;grid-template-columns:1.4fr 1fr;gap:40px;align-items:center;padding-block:clamp(56px,8vw,96px);}
.join .en-sub{font-family:var(--ff-label);font-weight:600;letter-spacing:.26em;font-size:13px;text-transform:uppercase;display:block;margin-bottom:14px;opacity:.9;}
.join h2{margin:0;font-weight:900;font-size:clamp(30px,4.6vw,60px);line-height:1.05;}
.join h2 em{font-style:normal;-webkit-text-stroke:2px #fff;color:transparent;}
.join p{margin:18px 0 0;font-size:16px;font-weight:600;max-width:42ch;}
.join .j-cta{display:flex;flex-direction:column;gap:14px;}
.join .j-cta .micro{font-family:var(--ff-label);font-weight:500;letter-spacing:.14em;font-size:12px;text-transform:uppercase;opacity:.85;}

/* =========================================================
   PARTNERS
   ========================================================= */
.partners{background:var(--mist);}
.partner-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line);}
.partner{background:#fff;aspect-ratio:16/7;display:flex;align-items:center;justify-content:center;transition:.2s;}
.partner .ph{width:100%;height:100%;}
.partner:hover{background:var(--mist-2);}
.partner-note{margin-top:26px;text-align:center;color:var(--muted);font-size:13px;font-weight:600;}

/* =========================================================
   SOCIAL
   ========================================================= */
.social-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}
.soc{background:#fff;border:1px solid var(--line);display:flex;flex-direction:column;transition:.2s;}
.soc .s-head{display:flex;align-items:center;gap:12px;padding:18px 20px;border-bottom:1px solid var(--line);}
.soc .s-icon{width:40px;height:40px;background:var(--ink);color:#fff;display:flex;align-items:center;justify-content:center;font-family:var(--ff-display);font-size:18px;transform:skewX(var(--skew));}
.soc .s-icon span{transform:skewX(calc(-1 * var(--skew)));}
.soc.ig .s-icon{background:var(--red);}
.soc.x .s-icon{background:var(--ink);}
.soc.yt .s-icon{background:var(--blue);}
.soc .s-name{font-weight:900;font-size:15px;white-space:nowrap;}
.soc .s-handle{font-family:var(--ff-label);font-size:11px;letter-spacing:.08em;color:var(--muted);}
.soc .s-media{aspect-ratio:1;position:relative;}
.soc .s-media > .ph{position:absolute;inset:0;}
.soc.yt .s-media{aspect-ratio:16/9;}
.soc .s-foot{padding:14px 20px;display:flex;justify-content:space-between;align-items:center;}
.soc .s-foot .follow{font-family:var(--ff-label);font-weight:600;font-size:12px;letter-spacing:.1em;text-transform:uppercase;}
.soc .s-foot .cnt{font-weight:900;font-size:14px;}
.soc:hover{box-shadow:0 14px 34px rgba(15,23,42,.12);}

/* =========================================================
   ACCESS
   ========================================================= */
.access{background:var(--navy);color:#fff;}
.access-grid{display:grid;grid-template-columns:1fr 1fr;gap:0;border:1px solid var(--line-dark);}
.access-map{position:relative;min-height:380px;}
.access-map .ph{position:absolute;inset:0;}
.access-info{padding:clamp(28px,4vw,52px);display:flex;flex-direction:column;justify-content:center;gap:18px;}
.access-info .en-sub{font-family:var(--ff-label);font-weight:600;letter-spacing:.26em;color:var(--red);font-size:13px;text-transform:uppercase;}
.access-info h3{margin:0;font-weight:900;font-size:clamp(22px,2.6vw,30px);}
.access-info .ai-row{display:flex;gap:14px;padding:14px 0;border-bottom:1px solid var(--line-dark);}
.access-info .ai-row .k{font-family:var(--ff-label);font-weight:600;font-size:11px;letter-spacing:.14em;color:var(--muted-on-dark);width:90px;flex:none;text-transform:uppercase;padding-top:3px;}
.access-info .ai-row .v{font-weight:600;font-size:14px;color:#eef2f8;}

/* =========================================================
   FOOTER
   ========================================================= */
.site-footer{background:var(--ink);color:#cbd0d9;}
.footer-top{padding-block:clamp(48px,7vw,80px);border-bottom:1px solid var(--line-dark);}
.footer-top .container{display:grid;grid-template-columns:1.5fr repeat(3,1fr);gap:36px;}
.f-brand .brand{margin:0 0 18px;}
.f-brand .brand .wd .jp{color:#fff;}
.f-brand p{font-size:13px;max-width:34ch;color:var(--muted-on-dark);}
.f-brand .f-soc{display:flex;gap:10px;margin-top:20px;}
.f-brand .f-soc a{width:40px;height:40px;border:1px solid var(--line-dark);display:flex;align-items:center;justify-content:center;font-family:var(--ff-label);font-weight:600;font-size:12px;transition:.2s;}
.f-brand .f-soc a:hover{background:var(--red);border-color:var(--red);color:#fff;}
.f-col h4{margin:0 0 16px;font-family:var(--ff-label);font-weight:600;letter-spacing:.14em;font-size:12px;color:#fff;text-transform:uppercase;}
.f-col ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:11px;}
.f-col a{font-size:13px;font-weight:600;}
.f-col a:hover{color:#fff;}
.footer-bottom{padding-block:22px;}
.footer-bottom .container{display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap;font-size:12px;color:var(--muted-on-dark);}
.footer-bottom .fb-links{display:flex;gap:20px;}

/* =========================================================
   SCROLL REVEAL
   ========================================================= */
.reveal{opacity:1;transform:none;}
.js-anim .reveal{opacity:0;transform:translateY(26px);transition:opacity .7s var(--ease),transform .7s var(--ease);}
.js-anim .reveal.in{opacity:1;transform:none;}
@media (prefers-reduced-motion:reduce){
  .js-anim .reveal{opacity:1;transform:none;transition:none;}
  .hero-slide{transition:none;}
}

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (max-width:1080px){
  .nav-links{display:none;}
  .nav-toggle{display:flex;}
  .matchbar .grid{grid-template-columns:1fr;}
  .matchbar .cell{border-right:none;border-bottom:1px solid var(--line-dark);}
  .news-grid{grid-template-columns:1fr 1fr;}
  .news-card.feature{grid-column:span 2;grid-row:auto;}
  .stat-grid{grid-template-columns:repeat(2,1fr);}
  .squad-grid{grid-template-columns:repeat(2,1fr);}
  .about-grid{grid-template-columns:1fr;}
  .about-media{order:-1;max-width:460px;}
  .join .container{grid-template-columns:1fr;}
  .partner-grid{grid-template-columns:repeat(2,1fr);}
  .access-grid{grid-template-columns:1fr;}
  .footer-top .container{grid-template-columns:1fr 1fr;}
}
@media (max-width:640px){
  .sec-titles h2{white-space:normal;}
  .util .u-left{display:none;}
  .util .container{justify-content:flex-end;}
  .hero-stage{height:clamp(480px,76vh,640px);}
  .ph.pos-left img,.ph.pos-right img{object-position:center;}
  .news-grid{grid-template-columns:1fr;}
  .news-card.feature{grid-column:auto;}
  .news-card .nc-ex{display:none;}
  .stat-grid{grid-template-columns:1fr 1fr;}
  .squad-grid{grid-template-columns:1fr 1fr;gap:12px;}
  .social-grid{grid-template-columns:1fr;}
  .about-facts{grid-template-columns:1fr;}
  .partner-grid{grid-template-columns:1fr 1fr;}
  .footer-top .container{grid-template-columns:1fr;}
  .brand .wd .en{display:none;}
  .brand .wd .jp{font-size:15px;white-space:nowrap;}

  /* --- モバイルはコンテンツを絞って縦長を抑制 --- */
  .section{padding-block:48px;}
  .news-grid .news-card:nth-child(n+4){display:none;}   /* ニュース 6→3件 */
  .partner-grid .partner:nth-child(n+5){display:none;}  /* スポンサー 8→4件 */
  .soc .s-media{aspect-ratio:16/9;}                     /* SNS画像を縮めて短く */
  .matchbar .results .res:nth-child(n+5){display:none;} /* 直近結果 4→3件 */
}
