/* ============================================================
   FootballNine 제품 앱 공유 테마 — Apple Music 라이트 + 레드
   v1-home / v1-rating / v1-board 공용
   ============================================================ */
@import url('https://cdn.jsdelivr.net/npm/@fontsource-variable/hubot-sans@5/index.css');
:root{
  --bg:#ffffff;--side:#fbfbfd;--text:#1d1d1f;--sub:#86868b;--sub2:#aeaeb2;
  --hair:#e8e8ed;--hair-2:#f0f0f3;--hover:#f5f5f7;
  --accent:#d83131;--accent-soft:#fdecef;--accent-ink:#b32323;
  --online:#34c759;
  --ink:#1d1d1f;--ink-soft:#48484a;--good:#1a7f37;--accent-line:#f3d3d6;
  --sans:"SUIT Variable",system-ui,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0;}
html,body{overflow-x:hidden;}
body{background:var(--bg);color:var(--text);font-family:var(--sans);line-height:1.5;letter-spacing:-.04em;-webkit-font-smoothing:antialiased;word-break:keep-all;height:100vh;overflow:hidden;display:flex;flex-direction:column;}
a{color:inherit;text-decoration:none;}
::selection{background:var(--accent);color:#fff;}
svg{display:block;}

.mockstrip{background:var(--hover);color:var(--sub);font:600 11px/1 var(--sans);letter-spacing:.04em;padding:8px 18px;display:flex;justify-content:space-between;border-bottom:1px solid var(--hair);}
.mockstrip a{color:var(--text);}

.shell{flex:1;min-height:0;display:flex;}

/* SIDEBAR */
.side{width:256px;flex:none;display:flex;flex-direction:column;min-height:0;background:var(--side);border-right:1px solid var(--hair);}
.spanel{background:transparent;}
.snav{padding:16px 14px;border-bottom:1px solid var(--hair);}
.slib{flex:1;min-height:0;display:flex;flex-direction:column;padding:10px 14px;overflow-y:auto;}
.logo-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px;}
.logo{display:flex;align-items:center;padding:2px 10px;font-family:'Hubot Sans Variable',var(--sans);font-weight:400;font-size:15px;letter-spacing:-.08em;color:var(--text);}
.nav a{display:flex;align-items:center;gap:14px;font-weight:600;font-size:15px;color:var(--text);padding:10px 10px;border-radius:8px;text-decoration:none;}
.nav a svg{width:23px;height:23px;flex:none;color:var(--sub);}
.nav a:hover{background:var(--hover);}
.nav a.on{color:var(--accent);}
.nav a.on svg{color:var(--accent);}

/* 사이드바 slib 패널의 채널 링크 — text-decoration 보정 (목업 v1-nation 기반) */
.chan{text-decoration:none;color:var(--text);}
.subchan{text-decoration:none;}
.subchan[aria-disabled="true"]{opacity:.55;pointer-events:none;}
/* W2 로그인 도입 전까지 팔로우 칩 숨김 (HTML은 유지 — 활성화는 본 룰 제거만) */
.chan .vfollow{display:none;}
.grp{font-weight:700;font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--sub2);padding:6px 10px 8px;}
.chan{display:flex;align-items:center;gap:11px;padding:8px 10px;border-radius:8px;cursor:pointer;}
.chan:hover,.chan.on{background:var(--hover);}
.chan .tile{width:24px;height:24px;border-radius:6px;flex:none;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:9.5px;color:#fff;}
.chan .tile.wc-tile{background:transparent;color:var(--text);box-shadow:none;}
.chan .tile.wc-tile svg{width:20px;height:20px;}
.chan .tile.circ{border-radius:50%;font-size:8.5px;}
img.tile{border-radius:50%;object-fit:cover;box-shadow:0 0 0 1px rgba(0,0,0,.07),0 1px 3px rgba(0,0,0,.12);}
.chan .ct{flex:1;min-width:0;font-weight:600;font-size:15px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.chan .badge{font:700 11px/1 var(--sans);background:var(--accent);color:#fff;padding:3px 7px;border-radius:99px;flex:none;}
.chan .vfollow{flex:none;font:700 11px/1 var(--sans);color:var(--accent);border:1px solid var(--accent);border-radius:99px;padding:4px 9px;background:var(--bg);cursor:pointer;font-family:inherit;}
.chan .vfollow:hover,.chan .vfollow.on{background:var(--accent);color:#fff;}
.subchans{margin:1px 0 8px;}
.subchan{display:block;padding:7px 10px 7px 28px;border-radius:7px;font-weight:600;font-size:14px;color:var(--sub);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.subchan:hover{color:var(--ink);}
.subchan.on{color:var(--ink);font-weight:800;background:var(--hover);}
.subchan .h{color:var(--sub2);margin-right:5px;}
.side .me{margin-top:auto;display:flex;align-items:center;gap:10px;padding:10px;border-top:1px solid var(--hair);}
.side .me .av{width:30px;height:30px;border-radius:50%;background:#c7c7cc;color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:12px;}
.side .me .n{font-weight:600;font-size:13px;}.side .me .s{font-size:11px;color:var(--online);font-weight:600;}
/* .auth 블록 폐기(2026-05-28) — 로그인은 로고 옆 .logo-login으로 이동 */

/* MAIN */
.main{flex:1;min-width:0;min-height:0;display:flex;flex-direction:column;background:var(--bg);overflow:hidden;}
.backdrop{display:none;}

/* condensed sticky header — team 페이지에서만 (hero 스크롤 후 슬라이드인). JS: header.js */
.cond-head{position:fixed;top:0;left:256px;right:0;z-index:40;height:52px;padding:0 32px;display:flex;align-items:center;gap:12px;background:rgba(255,255,255,.85);-webkit-backdrop-filter:blur(20px) saturate(180%);backdrop-filter:blur(20px) saturate(180%);border-bottom:1px solid var(--hair);transform:translateY(-100%);transition:transform .26s cubic-bezier(.32,.72,0,1),box-shadow .26s cubic-bezier(.32,.72,0,1);will-change:transform;}
.cond-head.visible{transform:translateY(0);box-shadow:0 4px 22px -12px rgba(0,0,0,.16);}
.cond-head .ch-flag{width:28px;height:28px;border-radius:50%;box-shadow:0 0 0 1px rgba(0,0,0,.08),0 2px 4px rgba(0,0,0,.06);flex:none;object-fit:cover;background:#fff;}
.cond-head .ch-icon{display:flex;align-items:center;justify-content:center;width:28px;height:28px;flex:none;color:var(--text);}
.cond-head .ch-icon svg{width:22px;height:22px;}
.cond-head .ch-name{font-weight:800;font-size:15.5px;letter-spacing:-.02em;color:var(--text);}
.cond-head .ch-cta{background:var(--text);color:#fff;border:none;font:800 12.5px/1 var(--sans);padding:8px 15px;border-radius:99px;cursor:pointer;font-family:inherit;letter-spacing:-.005em;display:none;}
/* article 모드 (매거진 에피소드 상세) — 시리즈명 + "— N편" 접미사 + 우측 back 링크. */
.cond-head .ch-title-group{flex:1 1 auto;min-width:0;display:flex;align-items:baseline;gap:6px;overflow:hidden;}
.cond-head .ch-title-group .ch-name{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.cond-head .ch-suffix{font-family:var(--sans);font-weight:800;font-size:15.5px;letter-spacing:-.02em;line-height:1.2;color:var(--sub);flex:none;white-space:nowrap;}
.cond-head .ch-back{margin-left:auto;margin-right:48px;display:inline-flex;align-items:center;gap:5px;font:700 12.5px/1 var(--sans);color:var(--sub);text-decoration:none;letter-spacing:-.005em;padding:7px 12px;border-radius:99px;transition:color .15s,background .15s;}
.cond-head .ch-back:hover{color:var(--text);background:var(--hover);}
/* W2 로그인 도입 전까지 cond-head 팔로우 칩 숨김(html은 유지 — 활성화는 display rule 제거) */

/* 글로벌 검색(.gsearch-*) · 로그인 버튼(.logo-login) 은 v0 출시 sweep 으로 HTML/CSS 제거. 활성화 시 재도입. */
.sp-rowwrap{display:flex;gap:8px;overflow-x:auto;padding:0 16px 6px;}
.sp-rowwrap::-webkit-scrollbar{height:0;}
.sp-chip{display:inline-flex;align-items:center;gap:9px;padding:7px 15px 7px 7px;border:1px solid var(--hair);border-radius:99px;flex:none;cursor:pointer;background:var(--bg);transition:.13s;}
.sp-chip:hover{background:var(--hover);border-color:var(--accent);}
.sp-chip .ic{width:24px;height:24px;border-radius:50%;flex:none;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:8.5px;color:#fff;overflow:hidden;}
.sp-chip .ic img{width:100%;height:100%;}
.sp-chip .nm{font-weight:600;font-size:14px;color:var(--text);white-space:nowrap;}

@media(max-width:860px){
  .side{position:fixed;left:0;top:0;bottom:0;z-index:50;width:284px;max-width:84vw;background:var(--side);transform:translateX(-100%);transition:transform .26s ease;box-shadow:6px 0 34px rgba(0,0,0,.2);}
  .shell.nav-open .side{transform:none;}
  .shell.nav-open .backdrop{display:block;position:fixed;inset:0;background:rgba(0,0,0,.42);z-index:45;}
  .cond-head{left:0;padding:0 16px;}
  .mainpad{padding:16px 16px 48px;}
  .gsearch-btn{right:14px;top:7px;}
}
.mainpad{flex:1;min-height:0;overflow-y:auto;padding:18px 32px 56px;}

h1.big{font-weight:800;font-size:clamp(30px,4.5vw,40px);letter-spacing:-.035em;margin:6px 0 6px;}
.subline{font-size:14px;color:var(--sub);font-weight:500;margin-bottom:24px;}
.subline .dot{width:8px;height:8px;border-radius:50%;background:var(--online);display:inline-block;margin-right:5px;vertical-align:middle;}
.subline b{color:var(--text);font-weight:600;}

.chips{display:flex;gap:8px;margin-bottom:26px;flex-wrap:wrap;}
.chip{background:var(--hover);color:var(--text);font-weight:600;font-size:13px;padding:8px 15px;border-radius:99px;cursor:pointer;}
.chip.on{background:var(--text);color:#fff;}

/* entity detail header (Apple Music 플레이리스트 헤더 스타일, 컴팩트) — 팀·리그·선수·국가 공통 */
.detail-head{display:flex;gap:22px;align-items:flex-start;padding:8px 0 22px;border-bottom:1px solid var(--hair);margin-bottom:8px;}
.dh-cover{width:142px;height:142px;border-radius:14px;flex:none;box-shadow:0 12px 30px -10px rgba(0,0,0,.38);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:9px;color:#fff;text-align:center;}
.dh-cover img{width:58px;height:58px;}
.dh-cover .cc{font-weight:800;font-size:13px;letter-spacing:.01em;}
/* 유니폼 커버: 빈 홈/어웨이 킷 1장 + 숫자 오버레이 (블랭크 킷으로 모든 번호 표현) */
.dh-cover.kit-only{background:none;box-shadow:none;border-radius:0;}
.kit-wrap{position:relative;width:100%;height:100%;container-type:size;}
.kit-wrap img{width:100%;height:100%;object-fit:contain;display:block;filter:drop-shadow(0 4px 9px rgba(0,0,0,.26));}
.kit-num{position:absolute;left:0;right:0;top:40%;transform:translateY(-50%);text-align:center;font:800 27cqw/1 var(--sans);color:var(--num,#fff);letter-spacing:-.02em;text-shadow:0 1px 4px rgba(0,0,0,.28);pointer-events:none;}
.dh-info{min-width:0;}
.dh-kind{font:600 11px/1 var(--sans);letter-spacing:.08em;text-transform:uppercase;color:var(--sub);}
.dh-kind{margin-bottom:9px;}
.dh-title{font-weight:800;font-size:clamp(24px,3.4vw,30px);letter-spacing:-.03em;margin:0 0 3px;}
.dh-sub{font-weight:700;font-size:15px;color:var(--accent-ink);}
.dh-desc{font-size:13.5px;color:var(--sub);margin-top:11px;max-width:46em;line-height:1.55;}
.dh-info{position:relative;padding-right:120px;}
.dh-cta{position:absolute;top:0;right:0;display:inline-flex;align-items:center;gap:7px;background:var(--text);color:#fff;font-weight:700;font-size:13px;padding:9px 16px;border-radius:99px;cursor:pointer;border:none;letter-spacing:-.02em;font-family:inherit;}
.dh-cta:hover{background:#000;}
@media(max-width:620px){.detail-head{flex-direction:column;align-items:flex-start;gap:16px;}.dh-cover{width:100px;height:100px;}}

/* apple feature cards */
.fcards{display:grid;grid-template-columns:1fr 1fr;gap:26px;margin-bottom:14px;}
.fcard{cursor:pointer;}
.fcard .flabel{font-size:13px;color:var(--sub);font-weight:600;}
.fcard .ftitle{font-size:19px;font-weight:700;color:var(--text);margin-top:5px;letter-spacing:-.02em;}
.fcard .fsub{font-size:14px;color:var(--sub);margin-top:2px;}
.fimg{margin-top:13px;border-radius:12px;aspect-ratio:16/9;position:relative;overflow:hidden;box-shadow:0 1px 4px rgba(0,0,0,.08);display:flex;align-items:flex-end;transition:.2s;}
.fcard:hover .fimg{box-shadow:0 6px 20px rgba(0,0,0,.14);}
.fimg .ov{padding:16px 18px;font-size:13.5px;color:#fff;font-weight:500;background:linear-gradient(transparent,rgba(0,0,0,.45));width:100%;line-height:1.45;}
.fimg .big{position:absolute;top:18px;left:20px;font-weight:800;font-size:26px;color:#fff;letter-spacing:-.02em;line-height:1.05;}
@media(max-width:760px){.fcards{grid-template-columns:1fr;}}

/* section header */
.sh{display:flex;align-items:center;gap:6px;margin:34px 0 14px;}
.sh h2{font-weight:800;font-size:21px;letter-spacing:-.025em;}
.sh .chev{color:var(--sub2);font-size:18px;}
.sh .sort{margin-left:auto;font-size:13px;color:var(--sub);font-weight:600;}

/* horizontal carousel cards (home) */
.row{display:flex;gap:20px;overflow-x:auto;padding-bottom:8px;}
.row::-webkit-scrollbar{height:0;}
.mcard{width:188px;flex:none;cursor:pointer;}
.mimg{aspect-ratio:1;border-radius:12px;box-shadow:0 1px 4px rgba(0,0,0,.08);position:relative;overflow:hidden;display:flex;align-items:flex-end;transition:.2s;}
.mcard:hover .mimg{box-shadow:0 6px 18px rgba(0,0,0,.14);transform:translateY(-2px);}
.mimg .lab{position:absolute;top:14px;left:15px;right:15px;font-weight:800;font-size:19px;color:#fff;letter-spacing:-.02em;line-height:1.05;}
.mimg .ovs{padding:12px 14px;font-size:12px;color:#fff;font-weight:500;background:linear-gradient(transparent,rgba(0,0,0,.5));width:100%;}
/* light(소프트 chill) 변형 — 옅은 뉴트럴 패널 + 다크 텍스트 */
.fimg.light{box-shadow:0 1px 2px rgba(0,0,0,.04);}
.fimg.light .big{color:var(--text);}
.fimg.light .ov{color:var(--ink-soft);background:none;}
.mimg.light{box-shadow:0 1px 2px rgba(0,0,0,.04);}
.mimg.light .lab{color:var(--text);}
.mimg.light .ovs{color:var(--ink-soft);background:none;}
.mcard .mt{font-weight:600;font-size:14.5px;margin-top:10px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.mcard .ms{font-size:13px;color:var(--sub);margin-top:3px;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}

/* topic list */
.topics{border-top:1px solid var(--hair);}
.trk{display:grid;grid-template-columns:24px 1fr 56px 66px;gap:16px;align-items:center;padding:12px;border-bottom:1px solid var(--hair-2);border-radius:8px;cursor:pointer;}
.trk:hover{background:var(--hover);}
.trk .idx{color:var(--sub2);font-size:14px;text-align:center;font-weight:600;}
.trk .meta{display:flex;align-items:center;gap:13px;min-width:0;}
.tav{width:40px;height:40px;border-radius:50%;flex:none;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px;color:#fff;}
.trk .nm{font-weight:600;font-size:15px;color:var(--text);display:flex;align-items:center;gap:8px;flex-wrap:wrap;}
.trk .nm .notice{color:var(--accent);font-weight:700;font-size:12px;}
.tag{font:600 11px/1 var(--sans);padding:3px 8px;border-radius:5px;white-space:nowrap;color:var(--sub);background:var(--hover);}
.tag.rate{color:var(--accent-ink);background:var(--accent-soft);}
.trk .sub2c{font-size:13px;color:var(--sub);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:4px;}
.trk .rep{color:var(--sub);font-size:14px;text-align:right;font-weight:600;}
.trk .tm{color:var(--sub2);font-size:13px;text-align:right;}
.modnote{margin-top:16px;font-size:12.5px;color:var(--sub2);}
.modnote b{color:var(--sub);font-weight:600;}
@media(max-width:820px){.trk{grid-template-columns:24px 1fr 56px;}.trk .tm{display:none;}}

/* friend activity */
.fa-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px 24px;}
.fa{display:flex;gap:12px;padding:10px;border-radius:8px;cursor:pointer;}
.fa:hover{background:var(--hover);}
.fa .av{width:36px;height:36px;border-radius:50%;flex:none;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:12px;color:#fff;position:relative;}
.fa .av.online::after{content:"";position:absolute;right:-1px;bottom:-1px;width:10px;height:10px;border-radius:50%;background:var(--online);border:2px solid var(--bg);}
.fa .who{font-weight:600;font-size:14px;}
.fa .act{font-size:13px;color:var(--sub);}
.fa .tm{font-size:11px;color:var(--sub2);margin-top:1px;}
@media(max-width:760px){.fa-grid{grid-template-columns:1fr;}}

/* subscribe card */
.subcard{margin-top:30px;background:var(--hover);border-radius:12px;padding:22px 24px;display:flex;align-items:center;gap:20px;flex-wrap:wrap;}
.subcard .st{flex:1;min-width:200px;}
.subcard h4{font-weight:700;font-size:16px;letter-spacing:-.01em;}
.subcard p{font-size:13.5px;color:var(--sub);margin-top:5px;}
.subcard .form{display:flex;gap:8px;}
.subcard input{border:1px solid var(--hair);border-radius:99px;padding:11px 16px;font-family:var(--sans);font-size:13.5px;width:200px;background:#fff;}
.subcard .sub{background:var(--accent);color:#fff;font-weight:700;font-size:13.5px;border:none;border-radius:99px;padding:11px 20px;cursor:pointer;}

/* ===== RATING (평가 화면) ===== */
.verdict{background:var(--hover);border-radius:16px;padding:26px 28px;display:flex;gap:32px;align-items:center;flex-wrap:wrap;margin-bottom:14px;}
.verdict .score{text-align:center;flex:none;}
.verdict .score .n{font-weight:800;font-size:64px;line-height:.85;color:var(--accent);letter-spacing:-.04em;}
.verdict .score .o{font-size:13px;color:var(--sub);font-weight:600;margin-top:4px;}
.verdict .bits{flex:1;min-width:220px;display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.verdict .bit .l{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--sub);}
.verdict .bit .v{font-size:16px;font-weight:700;margin-top:4px;}
.verdict .bit .v small{font-weight:600;font-size:12px;color:var(--sub);}
.rateblock{background:#fff;border:1px solid var(--hair);border-radius:14px;padding:20px 22px;margin-bottom:24px;}
.rateblock .q{font-weight:700;font-size:16px;}
.rateblock .q span{color:var(--sub);font-weight:500;font-size:13px;margin-left:6px;}
.scale{display:flex;gap:6px;margin-top:14px;}
.scale button{flex:1;min-width:0;height:42px;border:1px solid var(--hair);background:#fff;border-radius:9px;font:700 14px/1 var(--sans);color:var(--text);cursor:pointer;transition:.12s;}
.scale button:hover{border-color:var(--accent);color:var(--accent);}
.scale button.on{background:var(--accent);color:#fff;border-color:var(--accent);}
.rateres{margin-top:14px;font-size:14px;font-weight:600;color:var(--text);display:none;}
.rateres.show{display:block;}
.rateres b{color:var(--accent-ink);}
.me-pill{font:700 12px/1 var(--sans);color:var(--accent-ink);background:var(--accent-soft);padding:7px 11px;border-radius:8px;cursor:pointer;white-space:nowrap;}
.me-pill.empty{color:var(--sub);background:var(--hover);}

/* ============================================================
   Auth Modal — 로그인/가입 다이얼로그 (앱 전역)
   ============================================================ */
.fn-modal-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.42);display:none;align-items:center;justify-content:center;z-index:100;backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px);}
.fn-modal-backdrop.open{display:flex;animation:fnFade .15s ease-out;}
@keyframes fnFade{from{opacity:0}to{opacity:1}}
.fn-modal{background:#fff;border-radius:16px;width:min(420px,calc(100vw - 32px));padding:30px 28px 24px;box-shadow:0 18px 48px -12px rgba(0,0,0,.32);position:relative;}
.fn-modal-close{position:absolute;top:14px;right:14px;background:none;border:none;color:var(--sub);cursor:pointer;padding:6px;line-height:0;border-radius:8px;}
.fn-modal-close:hover{background:var(--hover);color:var(--text);}
.fn-modal-logo{width:50px;height:50px;margin:0 auto 18px;display:flex;align-items:center;justify-content:center;background:var(--accent-soft);border-radius:12px;font:800 22px/1 var(--sans);color:var(--accent-ink);letter-spacing:-.04em;}
.fn-modal h2{font-weight:800;font-size:18px;letter-spacing:-.025em;text-align:center;margin:0 0 6px;}
.fn-modal .fn-sub{text-align:center;font-size:13.5px;color:var(--sub);margin:0 0 22px;}
.fn-modal .fn-sub a{color:var(--accent);font-weight:700;cursor:pointer;}
.fn-modal input[type="email"]{width:100%;border:1.5px solid var(--accent);border-radius:10px;padding:13px 14px;font:600 14px/1 var(--sans);color:var(--text);outline:none;margin-bottom:10px;font-family:inherit;letter-spacing:-.02em;background:var(--bg);}
.fn-modal input[type="email"]::placeholder{color:var(--sub2);font-weight:500;}
.fn-modal .fn-primary{width:100%;background:var(--accent);color:#fff;border:none;border-radius:10px;padding:13px;font:800 14.5px/1 var(--sans);cursor:pointer;font-family:inherit;letter-spacing:-.02em;}
.fn-modal .fn-primary:hover{background:var(--accent-ink);}
.fn-modal .fn-or{display:flex;align-items:center;gap:12px;margin:14px 0;color:var(--sub2);font:700 11px/1 var(--sans);letter-spacing:.1em;}
.fn-modal .fn-or::before,.fn-modal .fn-or::after{content:"";flex:1;height:1px;background:var(--hair);}
.fn-modal .fn-secondary{width:100%;background:none;color:var(--text);border:1px solid var(--hair);border-radius:10px;padding:13px;font:700 14px/1 var(--sans);cursor:pointer;font-family:inherit;letter-spacing:-.02em;}
.fn-modal .fn-secondary:hover{border-color:var(--text);}

/* ============================================================
   WC 허브 — 참가국 그리드 · 12개조 카드 · 일정 (v1-wchub-mockup.html에서 포팅)
   ============================================================ */
.groups{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;}
.gcard{border:1px solid var(--hair);border-radius:12px;padding:14px 16px;}
.gcard .gh{font-weight:800;font-size:14px;margin-bottom:9px;color:var(--sub);}
.gcard .gn{display:flex;align-items:center;gap:9px;font-size:13.5px;color:var(--ink-soft);padding:5px 0;text-decoration:none;transition:color .12s;}
.gcard .gn:hover{color:var(--accent-ink);}
.gcard .gn .gd{width:20px;height:20px;flex:none;border-radius:50%;box-shadow:0 0 0 1px rgba(0,0,0,.06),0 1px 3px rgba(0,0,0,.1);}

.sched{margin-top:2px;}
.sd{display:flex;align-items:center;gap:9px;font:700 12px/1 var(--sans);letter-spacing:.04em;color:var(--sub);margin:20px 0 8px;}
.sd .dd{font-weight:700;color:var(--accent-ink);}
.fx{display:grid;grid-template-columns:60px 1fr auto;gap:14px;align-items:center;padding:12px;border-top:1px solid var(--hair-2);border-radius:8px;cursor:pointer;}
.fx:hover{background:var(--hover);}
.fx.me{background:var(--accent-soft);}
.fx .ftime{font-weight:800;font-size:14px;color:var(--text);text-align:center;}
.fx .ftime small{display:block;font-weight:600;font-size:10px;color:var(--sub2);margin-top:3px;letter-spacing:.02em;}
.fx .fmatch{display:flex;align-items:center;gap:10px;min-width:0;flex-wrap:wrap;}
.fx .ft{display:flex;align-items:center;gap:7px;}
.fx .ft img{width:22px;height:22px;border-radius:50%;box-shadow:0 0 0 1px rgba(0,0,0,.06),0 1px 3px rgba(0,0,0,.1);object-fit:cover;background:var(--surface,var(--hover));}
.fx .ft .tnm{font-weight:600;font-size:14px;}
.fx .vs{font:700 11px/1 var(--sans);color:var(--sub2);}
.fx .fgrp{font:700 11px/1 var(--sans);color:var(--sub);background:var(--hover);padding:5px 10px;border-radius:6px;white-space:nowrap;}
.fx.me .fgrp{background:#fff;color:var(--accent-ink);}
@media(max-width:860px){.groups{grid-template-columns:1fr 1fr;}}
@media(max-width:560px){.groups{grid-template-columns:1fr;}}

/* ============================================================
   팀 상세 페이지 — Hero · 일정 그리드 · 최근 전적 표 · 주요 선수 카드
   (v1-nation-mockup.html 포팅; 팔로우 CTA는 W2 로그인 도입 전 숨김)
   ============================================================ */
.detail-head{display:flex;align-items:center;gap:18px;margin-bottom:24px;}
.detail-head .dh-flag{width:88px;height:88px;border-radius:50%;flex:none;box-shadow:0 8px 22px -6px rgba(0,0,0,.18),0 0 0 1px rgba(0,0,0,.06);object-fit:cover;background:#fff;}
.detail-head .dh-info{flex:1;min-width:0;padding-right:0;position:static;}
.detail-head .dh-title-row{display:flex;align-items:center;gap:14px;flex-wrap:wrap;}
.detail-head .dh-title{font-weight:800;font-size:clamp(20px,2.6vw,24px);letter-spacing:-.025em;margin:0;}
.detail-head .dh-sub{font-size:14px;color:var(--text);margin-top:6px;letter-spacing:-.01em;}
.detail-head .dh-sub .muted{color:var(--sub);font-weight:600;}
.detail-head .dh-coach{font-size:13px;color:var(--sub);margin-top:4px;}
.detail-head .dh-coach b{color:var(--text);font-weight:700;margin-left:4px;}
/* dh-cta는 .dh-title-row 안에서 inline. W2 로그인 전까지 숨김(html은 유지). */
.detail-head .dh-cta{position:static;flex:none;background:var(--text);color:#fff;border:none;padding:9px 16px;border-radius:99px;font-weight:700;font-size:13px;cursor:pointer;font-family:inherit;letter-spacing:-.02em;display:none;}
.detail-head .dh-cta:hover{background:#000;}
.sh .all{margin-left:auto;font-size:13px;color:var(--accent-ink);font-weight:700;text-decoration:none;}

/* 일정 카드 그리드 */
.fxgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;}
.fxc{background:#fff;border:1px solid var(--hair);border-radius:12px;padding:18px 20px;text-decoration:none;color:var(--text);cursor:pointer;transition:.15s;display:block;}
.fxc:hover{border-color:var(--text);transform:translateY(-2px);box-shadow:0 8px 22px -10px rgba(0,0,0,.12);}
.fxc-h{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap;row-gap:8px;margin-bottom:18px;}
.fxc-rd{font:700 11px/1 var(--sans);background:var(--accent-soft);color:var(--accent-ink);padding:5px 9px;border-radius:5px;letter-spacing:-.005em;white-space:nowrap;}
.fxc-dt{font:700 12.5px/1 var(--sans);color:var(--sub);letter-spacing:-.005em;white-space:nowrap;}
.fxc-dt b{color:var(--text);font-weight:700;}
.fxc-mt{display:grid;grid-template-columns:1fr auto 1fr;gap:10px;align-items:center;padding:6px 0 4px;}
.fxc-tm{display:flex;flex-direction:column;align-items:center;gap:8px;text-align:center;min-width:0;}
.fxc-tm img{width:38px;height:38px;border-radius:50%;box-shadow:0 0 0 1px rgba(0,0,0,.06),0 2px 4px rgba(0,0,0,.08);object-fit:cover;background:#fff;}
.fxc-tm span{font-weight:700;font-size:13.5px;color:var(--text);letter-spacing:-.015em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%;}
.fxc-vs{font:700 11px/1 var(--sans);color:var(--sub2);letter-spacing:.06em;}
.fxc-venue{font:600 12px/1.3 var(--sans);color:var(--sub);margin-top:12px;letter-spacing:-.005em;text-align:center;}

/* 최근 전적 표 */
.rrlist{border-radius:14px;overflow-x:auto;background:#fbfbfb;margin-top:2px;}
.rrhead,.rrow{display:grid;grid-template-columns:92px 44px 1fr 64px 14px;gap:8px;align-items:center;padding:12px 16px;min-width:580px;}
.rrhead{font:700 11px/1 var(--sans);letter-spacing:.03em;color:var(--sub2);}
.rrhead span{text-align:center;}
.rrow{border-top:1px solid var(--hair-2);cursor:pointer;text-decoration:none;color:var(--text);font-size:13.5px;}
.rrow:hover{background:rgba(0,0,0,.045);}
.rr-d{font-weight:700;color:var(--text);letter-spacing:-.005em;text-align:center;}
.rr-d small{color:var(--sub);font-weight:600;font-size:11.5px;margin-left:4px;}
.rr-cat{font:700 10.5px/1 var(--sans);background:var(--hover);color:var(--sub);padding:5px 9px;border-radius:5px;text-align:center;justify-self:center;letter-spacing:-.005em;white-space:nowrap;}
.rr-mt{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:11px;min-width:0;}
.rr-mt > .rr-t{justify-self:end;}
.rr-mt > .rr-t.away{justify-self:start;}
.rr-t{display:flex;align-items:center;gap:7px;font-weight:700;color:var(--text);letter-spacing:-.015em;}
.rr-t img{width:20px;height:20px;border-radius:50%;box-shadow:0 0 0 1px rgba(0,0,0,.06);flex:none;object-fit:cover;background:#fff;}
.rr-sc{font-weight:800;font-size:15px;letter-spacing:-.02em;color:var(--text);font-variant-numeric:tabular-nums;padding:0 4px;white-space:nowrap;}
.rr-res{font:800 11px/1 var(--sans);padding:6px 10px;border-radius:5px;color:#fff;letter-spacing:.04em;min-width:32px;text-align:center;justify-self:center;}
.rr-res.w{background:#1f9d55;}
.rr-res.d{background:#e6e6eb;color:var(--sub);}
.rr-res.l{background:#e5484d;}
.rr-arr{color:var(--sub2);font-size:16px;font-weight:600;text-align:center;line-height:1;}

/* 주요 선수 카드 가로 스크롤 */
.plrow{display:flex;gap:12px;overflow-x:auto;padding-bottom:6px;}
.plrow::-webkit-scrollbar{height:0;}
.plcard{width:128px;flex:none;background:#fff;border:1px solid var(--hair-2);border-radius:14px;padding:20px 14px 16px;text-align:center;cursor:pointer;transition:.15s;text-decoration:none;color:var(--text);}
.plcard:hover{border-color:var(--hair);transform:translateY(-2px);box-shadow:0 8px 22px -10px rgba(0,0,0,.1);}
.plav{width:62px;height:62px;border-radius:50%;margin:0 auto 14px;background:linear-gradient(135deg,#1f9e57,#0c4027);color:#fff;display:flex;align-items:center;justify-content:center;font:800 26px/1 var(--sans);letter-spacing:-.04em;box-shadow:0 6px 14px -4px rgba(31,158,87,.32);}
.plnm{font-weight:700;font-size:14px;letter-spacing:-.015em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.plpos{font:600 11.5px/1.3 var(--sans);color:var(--sub);margin-top:5px;letter-spacing:-.005em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}

@media(max-width:980px){.fxgrid{grid-template-columns:1fr;}}

/* ============================================================
   팀 경기 일정 페이지 (/teams/{slug}/fixtures) — 표 레이아웃은 team-detail 최근전적
   과 동일 (5컬럼, center 정렬). 추가 스타일은 "예정" 뱃지 + WC accent.
   ============================================================ */
.rr-res.ns{background:var(--hover);color:var(--sub);}
.rr-cat.wc{color:var(--accent-ink);background:var(--accent-soft);}

/* ============================================================
   팀 선수단 페이지 (/teams/{slug}/squad) — v1-nation-squad
   ============================================================ */
.filter-chips{display:flex;gap:8px;margin-bottom:8px;flex-wrap:wrap;}
.fc-chip{font:700 12.5px/1 var(--sans);background:var(--hover);color:var(--sub);padding:8px 14px;border-radius:99px;cursor:pointer;border:none;font-family:inherit;letter-spacing:-.005em;display:inline-flex;align-items:center;gap:7px;}
.fc-chip[disabled]{cursor:default;}
.fc-chip.on{background:var(--text);color:#fff;}
.fc-chip .ct{font:700 11px/1 var(--sans);color:var(--sub2);background:#fff;padding:3px 7px;border-radius:99px;letter-spacing:.04em;}
.fc-chip.on .ct{background:rgba(255,255,255,.18);color:#fff;}
.grp-h{display:flex;align-items:baseline;gap:10px;margin:34px 0 14px;}
.grp-h h2{font:800 18px/1 var(--sans);letter-spacing:-.02em;color:var(--text);}
.grp-h .ct{font:700 11px/1 var(--sans);color:var(--sub);letter-spacing:.06em;text-transform:uppercase;}
.grp-h .ct b{color:var(--text);}
.grp-h:first-of-type{margin-top:16px;}
.sq-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:10px;}
.sqr{background:#fff;border:1px solid var(--hair-2);border-radius:10px;display:grid;grid-template-columns:48px 1fr auto;gap:12px;align-items:center;padding:12px 14px;cursor:pointer;text-decoration:none;color:var(--text);transition:.15s;}
.sqr:hover{border-color:var(--hair);transform:translateY(-1px);box-shadow:0 6px 14px -6px rgba(0,0,0,.1);}
.sq-av{width:48px;height:48px;position:relative;flex:none;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#5b6b7a,#23303b);border-radius:50%;color:#fff;}
.sq-av .num{font:800 16px/1 var(--sans);letter-spacing:-.02em;}
.sq-text{min-width:0;}
.sq-nm{font-weight:700;font-size:14px;letter-spacing:-.015em;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.sq-meta{font:600 11.5px/1.3 var(--sans);color:var(--sub);letter-spacing:-.005em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.sq-pos{font:700 11px/1 var(--sans);color:var(--sub);background:var(--hover);padding:5px 9px;border-radius:5px;letter-spacing:.04em;}

/* ============================================================
   Talk & Talk 페이지 (/teams/{slug}/talk) — v1-nation-talk-board UI 셸
   board는 빈 상태(글 도메인 미도입) · scope-card 실 squad 노출.
   ============================================================ */
.pagewrap{display:flex;gap:34px;align-items:flex-start;margin-top:14px;}
.article{flex:1;min-width:0;}
.adrail{width:300px;flex:none;display:flex;flex-direction:column;gap:18px;}
@media(max-width:1200px){.adrail{display:none;}}

/* article 안 sh: 제목 + 검색 동일선상 */
.article .sh{margin:8px 0 18px;}
.feed-search{display:flex;align-items:center;gap:8px;background:var(--hover);border:1px solid var(--hair);border-radius:99px;padding:8px 14px;margin-left:auto;width:280px;max-width:60%;transition:.15s;}
.feed-search svg{width:15px;height:15px;color:var(--sub);flex:none;}
.feed-search input{border:none;background:none;outline:none;font:500 13.5px/1 var(--sans);color:var(--text);width:100%;letter-spacing:-.005em;font-family:inherit;}
.feed-search input::placeholder{color:var(--sub);}
.feed-search:focus-within{border-color:var(--accent);background:#fff;}

/* 컨트롤 바 (필터 칩 + 정렬) — talk 한정 (squad의 .filter-chips와 다른 레이아웃) */
.ctrl{display:flex;align-items:center;gap:14px;flex-wrap:wrap;margin-bottom:14px;}
.ctrl .filter-chips{display:flex;gap:6px;flex-wrap:wrap;flex:1;min-width:0;margin-bottom:0;}
.ctrl .fc-chip:not(.on):hover{background:var(--side);color:var(--text);}
.ctrl .sort{font:600 13px/1 var(--sans);color:var(--sub);letter-spacing:-.005em;cursor:default;padding:8px 12px;display:inline-flex;align-items:center;gap:5px;flex:none;}
.ctrl .sort b{color:var(--text);font-weight:700;}

/* 보드 — 전체일정 rrlist 컨벤션 (#fbfbfb, 14px radius, mono uppercase 헤더) */
.blist{border-radius:14px;overflow-x:auto;background:#fbfbfb;}
.bhead,.brow{display:grid;grid-template-columns:1fr 80px 80px 56px 56px;gap:14px;align-items:center;padding:13px 18px;min-width:680px;}
.bhead{font:700 11px/1 var(--mono,var(--sans));letter-spacing:.03em;color:var(--sub2);}
.bhead span{text-align:center;}
.brow{border-top:1px solid var(--hair-2);cursor:pointer;text-decoration:none;color:var(--text);font-size:13.5px;}
.brow:hover{background:rgba(0,0,0,.045);}
.brow.pinned{background:#fff7e5;}
.brow.pinned:hover{background:#fdefce;}
.b-title{display:flex;align-items:center;gap:8px;min-width:0;}
.b-title .ttl{font-weight:700;font-size:14.5px;letter-spacing:-.015em;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1;min-width:0;}
.b-tag{font:700 10.5px/1 var(--sans);padding:4px 8px;border-radius:5px;color:var(--sub);background:var(--hover);letter-spacing:-.005em;white-space:nowrap;flex:none;}
.b-tag.rate{color:var(--accent-ink);background:var(--accent-soft);}
.b-tag.notice{color:#b45309;background:#fef0e3;}
.b-from{font:700 11px/1 var(--sans);color:var(--sub);background:transparent;border:1px solid var(--hair);padding:4px 8px 4px 7px;border-radius:5px;display:inline-flex;align-items:center;gap:4px;letter-spacing:-.005em;white-space:nowrap;flex:none;}
.b-from::before{content:"↗";font:800 10px/1 var(--sans);color:var(--sub2);}
.b-author{font:600 13px/1 var(--sans);color:var(--sub);text-align:center;letter-spacing:-.005em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.b-time{font:600 12.5px/1 var(--sans);color:var(--sub2);text-align:center;letter-spacing:-.005em;white-space:nowrap;}
.b-replies{font:800 13.5px/1 var(--sans);color:var(--text);text-align:center;letter-spacing:-.015em;}
.b-likes{font:600 13px/1 var(--sans);color:var(--sub);text-align:center;letter-spacing:-.005em;}
.blist-empty{padding:40px 18px;text-align:center;border-top:1px solid var(--hair-2);}
.blist-empty p{font:600 14px/1.5 var(--sans);color:var(--text);letter-spacing:-.005em;}
.blist-empty p.muted{font-weight:500;font-size:12.5px;color:var(--sub);margin-top:6px;}

.pagi{margin-top:22px;display:flex;justify-content:center;}
.pagi-more{background:transparent;border:1px solid var(--hair);color:var(--text);font:700 13px/1 var(--sans);padding:13px 24px;border-radius:99px;cursor:pointer;font-family:inherit;letter-spacing:-.005em;}
.pagi-more:hover:not([disabled]){border-color:var(--text);}
.pagi-more[disabled]{color:var(--sub2);cursor:default;}

/* adrail 카드 — 글쓰기 · 범위 */
.write-card{background:#fff;border:1px solid var(--hair);border-radius:14px;padding:18px 18px 16px;}
.write-card h4{font-weight:800;font-size:15px;letter-spacing:-.02em;margin-bottom:6px;}
.write-card p{font-size:12.5px;color:var(--sub);line-height:1.5;font-weight:500;margin-bottom:14px;letter-spacing:-.005em;}
.write-btn{display:flex;align-items:center;justify-content:center;gap:6px;width:100%;background:var(--accent);color:#fff;border:none;font:800 13.5px/1 var(--sans);padding:12px;border-radius:99px;cursor:pointer;font-family:inherit;letter-spacing:-.005em;}
.write-btn:hover:not([disabled]){background:var(--accent-ink);}
.write-btn[disabled]{background:var(--sub2);cursor:default;}
.write-btn .plus{font-size:14px;line-height:1;}
/* write-card가 cond-head 뒤로 가려지면 별도 chip 등장 (검색 아이콘 좌측). 원래 write-btn은 flow 유지(scope-card 안 흔들리게). JS: header.js */
.write-btn-float{position:fixed;top:8px;right:80px;display:flex;align-items:center;justify-content:center;height:36px;padding:0 14px;background:var(--accent);color:#fff;border:none;font:800 12.5px/1 var(--sans);border-radius:99px;cursor:pointer;font-family:inherit;letter-spacing:-.005em;box-shadow:0 4px 14px -4px rgba(0,0,0,.18),0 0 0 1px rgba(0,0,0,.04);z-index:50;}
.write-btn-float:hover:not([disabled]){background:var(--accent-ink);}
.write-btn-float[disabled]{background:var(--sub2);cursor:default;}
.write-btn-float[hidden]{display:none;}
@media(max-width:860px){.write-btn-float{right:60px;}}

.scope-card{background:#fff;border:1px solid var(--hair);border-radius:14px;padding:16px 14px;}
.scope-head{display:flex;align-items:center;gap:6px;margin:0 6px 10px;}
.scope-card h4{font:700 10.5px/1 var(--sans);letter-spacing:.08em;text-transform:uppercase;color:var(--sub);margin:0;}
.scope-help{width:18px;height:18px;border-radius:50%;border:1px solid var(--hair);background:transparent;color:var(--sub);font:700 11px/1 var(--sans);cursor:pointer;font-family:inherit;display:flex;align-items:center;justify-content:center;padding:0;flex:none;}
.scope-help:hover{color:var(--text);border-color:var(--text);}
.scope-list{display:flex;flex-direction:column;gap:1px;}
.scope-row{display:flex;align-items:center;justify-content:space-between;padding:8px 10px;border-radius:7px;cursor:pointer;text-decoration:none;color:var(--text);font:600 13px/1.2 var(--sans);letter-spacing:-.005em;}
.scope-row:hover{background:var(--hover);}
.scope-row.on{background:var(--text);color:#fff;}
.scope-row .ct{font:700 11px/1 var(--sans);color:var(--sub2);letter-spacing:.04em;}
.scope-row.on .ct{color:rgba(255,255,255,.55);}
.scope-divider{height:1px;background:var(--hair-2);margin:6px 14px;}
.scope-list-more{margin-top:1px;}
.scope-list-more[hidden]{display:none;}
.scope-more-btn{width:100%;margin-top:6px;font:700 12.5px/1 var(--sans);color:var(--sub);background:transparent;border:none;cursor:pointer;padding:8px 10px;border-radius:7px;font-family:inherit;letter-spacing:-.005em;}
.scope-more-btn:hover{color:var(--text);background:var(--hover);}

/* scope-modal (최초 1회 — localStorage 'fn_scope_explainer_seen_v2'; 워딩 개정 시 v++). JS: header.js */
.scope-modal-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.42);z-index:100;display:none;align-items:center;justify-content:center;backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px);}
.scope-modal-backdrop.show{display:flex;animation:fnFade .15s ease-out;}
@keyframes fnFade{from{opacity:0}to{opacity:1}}
.scope-modal{background:#fff;border-radius:16px;padding:24px 24px 18px;max-width:380px;width:90%;box-shadow:0 24px 60px -16px rgba(0,0,0,.34);}
.scope-modal h3{font-weight:800;font-size:17px;letter-spacing:-.025em;margin-bottom:10px;color:var(--text);}
.scope-modal p{font-size:13.5px;line-height:1.6;color:var(--sub);letter-spacing:-.005em;margin-bottom:14px;}
.scope-modal p b{color:var(--text);font-weight:700;}
.scope-ex{background:var(--side);border:1px solid var(--hair-2);border-radius:10px;padding:8px 12px;margin:0 0 14px;}
.scope-ex .line{display:flex;align-items:baseline;gap:10px;padding:8px 0;font-size:13px;border-top:1px solid var(--hair-2);letter-spacing:-.005em;}
.scope-ex .line:first-child{border-top:none;}
.scope-ex .line .lbl{font-weight:700;color:var(--text);min-width:96px;flex:none;}
.scope-ex .line .desc{color:var(--sub);font-weight:500;}
.scope-modal-cta{display:flex;justify-content:flex-end;}
.scope-modal-btn{background:var(--text);color:#fff;font:800 13px/1 var(--sans);padding:10px 18px;border-radius:99px;cursor:pointer;border:none;font-family:inherit;letter-spacing:-.005em;}
.scope-modal-btn:hover{background:#000;}

/* ============================================================
   매치 상세 페이지 (/fixtures/{slug}) — v1-match-kr-cz mockup
   Phase A: hero(dh-match) · 최근 폼 · H2H · 관련 Talk
   ============================================================ */
.detail-head .dh-match{position:relative;width:96px;height:64px;flex:none;align-self:center;}
.detail-head .dh-match img{width:64px;height:64px;border-radius:50%;position:absolute;top:0;box-shadow:0 6px 16px -4px rgba(0,0,0,.18),0 0 0 1px rgba(0,0,0,.06);background:#fff;}
.detail-head .dh-match img.f1{left:0;}
.detail-head .dh-match img.f2{left:32px;border:3px solid #fff;}
.detail-head .dh-badge{font:800 11px/1 var(--sans);background:var(--accent);color:#fff;padding:7px 11px;border-radius:99px;letter-spacing:.06em;align-self:center;}
.detail-head .dh-badge.live{background:var(--accent);}
.detail-head .dh-badge.ft{background:var(--text);font-variant-numeric:tabular-nums;}

.sec{margin-top:32px;}
.sec h2{font-weight:800;font-size:18px;letter-spacing:-.02em;margin-bottom:14px;display:flex;align-items:baseline;gap:10px;}
.sec h2 .meta{font:600 12.5px/1 var(--sans);color:var(--sub);letter-spacing:-.005em;margin-left:auto;background:var(--side);padding:6px 11px;border-radius:99px;}

/* 최근 폼 */
.form-cmp{display:grid;grid-template-columns:1fr auto 1fr;gap:20px;align-items:center;background:#fff;border:1px solid var(--hair);border-radius:14px;padding:22px 24px;}
.fc-side{display:flex;flex-direction:column;align-items:center;}
.fc-h{display:flex;align-items:center;justify-content:center;gap:9px;margin-bottom:12px;}
.fc-h img{width:24px;height:24px;border-radius:50%;box-shadow:0 0 0 1px rgba(0,0,0,.06);}
.fc-h .nm{font-weight:700;font-size:14px;letter-spacing:-.015em;color:var(--text);}
.fc-strip{display:flex;justify-content:center;gap:5px;margin-bottom:16px;}
.fc-pill{width:26px;height:26px;border-radius:6px;color:#fff;font:800 11px/26px var(--sans);text-align:center;letter-spacing:.04em;}
.fc-pill.w{background:var(--good);}
.fc-pill.d{background:#e6e6eb;color:var(--sub);}
.fc-pill.l{background:var(--accent);}
.fc-stats{display:flex;justify-content:center;gap:20px;}
.fc-stats > div{text-align:center;}
.fc-stats b{font:800 17px/1 var(--sans);letter-spacing:-.025em;color:var(--text);display:block;}
.fc-stats span{font:600 10.5px/1 var(--sans);color:var(--sub2);text-transform:uppercase;letter-spacing:.06em;margin-top:5px;display:block;}
.fc-vs{font:700 11px/1 var(--sans);color:var(--sub2);letter-spacing:.06em;}

/* H2H */
.h2h-sum{display:grid;grid-template-columns:1fr auto 1fr;gap:24px;align-items:center;padding:18px 22px;background:var(--side);border:1px solid var(--hair-2);border-radius:14px;margin-bottom:12px;}
.h2h-side{display:flex;align-items:center;gap:14px;}
.h2h-side.mirror{flex-direction:row-reverse;}
.h2h-side img{width:32px;height:32px;border-radius:50%;box-shadow:0 0 0 1px rgba(0,0,0,.06);}
.h2h-stats{display:flex;gap:20px;}
.h2h-stats > div{text-align:center;}
.h2h-stats b{font-weight:800;font-size:20px;letter-spacing:-.025em;display:block;line-height:1;}
.h2h-stats .w b{color:var(--good);}
.h2h-stats .d b{color:var(--sub);}
.h2h-stats .l b{color:var(--accent-ink);}
.h2h-stats span{font:600 10.5px/1 var(--sans);color:var(--sub2);text-transform:uppercase;letter-spacing:.06em;margin-top:5px;display:block;}
.h2h-meta{text-align:center;padding:0 18px;border-left:1px solid var(--hair-2);border-right:1px solid var(--hair-2);}
.h2h-gd{font:800 22px/1 var(--sans);letter-spacing:-.025em;color:var(--text);font-variant-numeric:tabular-nums;}
.h2h-gdl{font:600 10.5px/1 var(--sans);color:var(--sub2);text-transform:uppercase;letter-spacing:.06em;margin-top:5px;}
@media(max-width:680px){
  .h2h-sum{grid-template-columns:1fr;}
  .h2h-side.mirror{flex-direction:row;}
  .h2h-meta{border:none;padding:0;}
  .form-cmp{grid-template-columns:1fr;}
  .fc-vs{display:none;}
}

/* FT 요약 카드 — 양 팀 + 큰 스코어 + FT 배지 (mockup .ft-hero). 득점선수(scorers)는 fixture_events 적재 후. */
.ft-hero{display:grid;grid-template-columns:1fr auto 1fr;gap:14px;align-items:center;background:#fff;border:1px solid var(--hair);border-radius:18px;padding:30px 32px;margin-bottom:14px;}
.ft-hero .team{display:flex;flex-direction:column;align-items:center;gap:11px;}
.ft-hero .team img{width:48px;height:48px;border-radius:50%;box-shadow:0 0 0 1px rgba(0,0,0,.06),0 2px 6px rgba(0,0,0,.08);}
.ft-hero .team .nm{font:800 15px/1 var(--sans);letter-spacing:-.02em;color:var(--text);}
.ft-hero .scoreblock{text-align:center;display:flex;flex-direction:column;align-items:center;gap:10px;}
.ft-hero .score{font:800 60px/.85 var(--sans);letter-spacing:-.04em;color:var(--text);font-variant-numeric:tabular-nums;}
.ft-hero .score .sep{color:var(--sub2);margin:0 6px;}
.ft-hero .ft-badge{font:800 11px/1 var(--sans);background:var(--text);color:#fff;padding:6px 12px;border-radius:99px;letter-spacing:.08em;}

/* 선수 상세 페이지 (/players/{apiId}) — Phase A. 선수 photo 미사용 (docs/PRE-LAUNCH-LEGAL.md). */
.fc-stats.pl-current{background:#fff;border:1px solid var(--hair);border-radius:14px;padding:22px 24px;justify-content:flex-start;}
.bhead.pl-career-head,.brow.pl-career-row{grid-template-columns:1fr 60px 60px 60px 60px;min-width:580px;}
.brow.pl-career-row{cursor:default;}
.brow.pl-career-row:hover{background:transparent;}
.brow.pl-career-row .ttl{white-space:normal;}

/* Eyebrow + by the numbers (선수 v2 mockup 차용) */
.pl-eyebrow{font:600 11px/1 var(--sans);letter-spacing:.08em;text-transform:uppercase;color:var(--sub);margin-bottom:6px;}
.btn-row{display:grid;grid-template-columns:repeat(5,1fr);padding:20px 0;border-bottom:1px solid var(--hair);margin-bottom:8px;align-items:center;}
.btn-col{padding:0 22px;border-right:1px solid var(--hair);text-align:center;display:flex;flex-direction:column;justify-content:center;gap:10px;}
.btn-col:last-child{border-right:none;}
.btn-col .l{font:600 11px/1 var(--sans);letter-spacing:.08em;text-transform:uppercase;color:var(--sub);margin:0;}
.btn-col .v{font-weight:800;font-size:36px;letter-spacing:-.035em;color:var(--text);line-height:1;}
.btn-col .v small{font-size:14px;color:var(--sub);font-weight:700;margin-left:3px;}
@media(max-width:860px){.btn-row{grid-template-columns:repeat(2,1fr);gap:18px 0;}.btn-col{border-right:none;padding:0 12px;}}

/* 선수 다음 경기 카드 */
.pl-upcoming{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px;}
.pl-up{background:#fff;border:1px solid var(--hair);border-radius:12px;padding:16px 18px;display:flex;flex-direction:column;gap:8px;text-decoration:none;color:var(--text);transition:.15s;}
.pl-up:hover{border-color:var(--text);transform:translateY(-2px);box-shadow:0 8px 22px -10px rgba(0,0,0,.12);}
.pl-up-comp{font:700 11px/1 var(--sans);letter-spacing:.06em;text-transform:uppercase;color:var(--sub);background:var(--hover);padding:5px 9px;border-radius:5px;align-self:flex-start;}
.pl-up-comp.wc{color:#fff;background:var(--accent);}   /* WC 본선만 강조 */
.pl-up-mt{font:800 14px/1.25 var(--sans);letter-spacing:-.015em;color:var(--text);}
.pl-up-when{font:600 12.5px/1 var(--sans);color:var(--sub);letter-spacing:-.005em;}
.pl-up-when b{color:var(--text);font-weight:700;}

/* 선수 최근 폼 행 (팀 상세 rrlist 변형) */
.rrhead.pl-form-head,.rrow{}
.rrhead{display:grid;grid-template-columns:88px 36px 1fr 80px 56px;gap:10px;padding:12px 16px;background:transparent;font:700 11px/1 var(--sans);letter-spacing:.04em;color:var(--sub2);text-transform:uppercase;}
.rrhead .h-mt{text-align:left;}
.rrhead .h-res{text-align:center;}
.rrow{display:grid;grid-template-columns:88px 36px 1fr 80px 56px;gap:10px;align-items:center;padding:12px 16px;border-top:1px solid var(--hair-2);text-decoration:none;color:var(--text);font-size:13.5px;}
.rrow:hover{background:rgba(0,0,0,.03);}
.rr-date{font:600 12.5px/1 var(--sans);color:var(--sub);font-variant-numeric:tabular-nums;}
.rr-mt{font-weight:700;letter-spacing:-.015em;}
.rr-score{font:800 13.5px/1 var(--sans);letter-spacing:-.02em;text-align:center;font-variant-numeric:tabular-nums;}
.rr-rating{font:800 14px/1 var(--sans);letter-spacing:-.025em;color:var(--text);text-align:center;font-variant-numeric:tabular-nums;}

/* ============================================================
   매거진 시리즈 — WC 허브 banner + /wc/series 페이지
   v1-wchub mockup .series-banner + v1-wc-series mockup .series-hero·ep-card·gtable
   ============================================================ */
/* WC 허브 promo banner (다크) */
/* 좌측 dark navy → 중앙 부드러운 그라데이션 → 우측 accent red. 두 영역 색을 한 컨테이너 위에서 자연 전환. */
.series-banner{display:grid;grid-template-columns:1.35fr 1fr;gap:0;border-radius:4px;overflow:hidden;background:linear-gradient(105deg,#0e1620 0%,#0e1620 45%,#3a0610 75%,#5a0d18 90%,#a8122a 100%);color:#fff;margin-bottom:22px;text-decoration:none;transition:transform .25s;}
.series-banner:hover{transform:translateY(-1px);}
.series-banner .sb-text{padding:32px 34px 30px;display:flex;flex-direction:column;justify-content:center;}
.series-banner .sb-label{font:700 10px/1 var(--sans);letter-spacing:.18em;color:rgba(255,255,255,.55);margin-bottom:16px;text-transform:uppercase;}
.series-banner .sb-label .new{font:700 10px/1 var(--sans);letter-spacing:.06em;background:var(--accent);color:#fff;padding:5px 9px;border-radius:99px;margin-left:10px;text-transform:none;}
.series-banner .sb-h{font-weight:800;font-size:30px;letter-spacing:-.03em;line-height:1.22;margin:0 0 14px;color:#fff;}
.series-banner .sb-d{font-size:13.5px;color:rgba(255,255,255,.7);margin:0 0 22px;line-height:1.6;letter-spacing:-.01em;max-width:30em;}
.series-banner .sb-cta{display:inline-flex;align-items:center;gap:10px;font:700 13px/1 var(--sans);color:#fff;letter-spacing:-.005em;}
.series-banner .sb-cta .arrow{transition:transform .2s;}
.series-banner:hover .sb-cta .arrow{transform:translateX(3px);}
/* sb-img 자체 배경 제거 — 부모(.series-banner)의 그라데이션이 자연스럽게 표시 */
.series-banner .sb-img{position:relative;min-height:200px;}
.series-banner .sb-img .ep{position:absolute;top:24px;right:26px;font:700 11px/1 var(--sans);letter-spacing:.06em;color:rgba(255,255,255,.85);font-variant-numeric:tabular-nums;}
.series-banner .sb-img .ctry{position:absolute;bottom:26px;right:26px;display:flex;align-items:center;gap:12px;}
.series-banner .sb-img .ctry img{width:36px;height:36px;border-radius:50%;box-shadow:0 0 0 1.5px rgba(255,255,255,.4),0 3px 12px rgba(0,0,0,.3);}
.series-banner .sb-img .ctry .nm{font-weight:800;font-size:22px;letter-spacing:-.022em;color:#fff;}
@media(max-width:760px){.series-banner{grid-template-columns:1fr;}.series-banner .sb-img{min-height:180px;}}

/* 시리즈 페이지 hero (큰 1편) */
.series-hero{display:grid;grid-template-columns:1.3fr 1fr;gap:24px;margin-bottom:14px;border-top:1px solid var(--text);padding-top:22px;text-decoration:none;color:inherit;}
.series-hero .sh-img{position:relative;aspect-ratio:3/2;max-height:380px;border-radius:4px;overflow:hidden;background:#1a1a1a;}
.series-hero .sh-img .bg{position:absolute;inset:0;transition:transform .5s cubic-bezier(.32,.72,0,1);}
.series-hero:hover .sh-img .bg{transform:scale(1.025);}
.series-hero .sh-img .ep-mark{position:absolute;top:24px;left:24px;font:700 11px/1 var(--sans);letter-spacing:.04em;color:rgba(255,255,255,.85);font-variant-numeric:tabular-nums;}
.series-hero .sh-img .ctry{position:absolute;bottom:30px;left:28px;display:flex;align-items:center;gap:14px;}
.series-hero .sh-img .ctry img{width:48px;height:48px;border-radius:50%;box-shadow:0 0 0 1.5px rgba(255,255,255,.4),0 4px 16px rgba(0,0,0,.3);}
.series-hero .sh-img .ctry .nm{font-weight:800;font-size:32px;letter-spacing:-.025em;color:#fff;}
.series-hero .sh-body{display:flex;flex-direction:column;justify-content:center;padding:8px 8px 8px 0;}
.series-hero .sb-cat{font-size:11.5px;font-weight:600;color:var(--accent);margin-bottom:14px;letter-spacing:-.005em;}
.series-hero .sb-cat .new{display:inline-flex;align-items:center;gap:5px;font:700 11px/1 var(--sans);letter-spacing:-.01em;background:var(--accent);color:#fff;padding:4px 9px;border-radius:99px;margin-left:10px;}
.series-hero .sb-title{font-size:28px;font-weight:700;line-height:1.28;letter-spacing:-.028em;margin:0 0 16px;color:var(--text);}
.series-hero .sb-deck{font-size:14.5px;line-height:1.65;color:var(--sub);margin:0 0 22px;letter-spacing:-.01em;}
.series-hero .sb-meta{font-size:12px;color:var(--sub);letter-spacing:-.005em;}
@media(max-width:760px){.series-hero{grid-template-columns:1fr;}}

/* 시리즈 페이지 ep-card grid */
.recent-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:22px 18px;margin-bottom:36px;}
.ep-card{display:block;color:inherit;text-decoration:none;}
.ep-card .ep-img{position:relative;aspect-ratio:1/1;border-radius:3px;overflow:hidden;margin-bottom:14px;transition:transform .4s cubic-bezier(.32,.72,0,1);}
.ep-card:hover .ep-img{transform:translateY(-2px);}
.ep-card .ep-img .bg{position:absolute;inset:0;}
.ep-card .ep-img .ep-mark{position:absolute;top:14px;left:14px;font:700 10px/1 var(--sans);letter-spacing:.04em;color:rgba(255,255,255,.85);font-variant-numeric:tabular-nums;}
.ep-card .ep-img .ctry{position:absolute;bottom:14px;left:14px;display:flex;align-items:center;gap:8px;}
.ep-card .ep-img .ctry img{width:26px;height:26px;border-radius:50%;box-shadow:0 0 0 1.5px rgba(255,255,255,.4),0 2px 8px rgba(0,0,0,.25);}
.ep-card .ep-img .ctry .nm{font-weight:800;font-size:16px;letter-spacing:-.022em;color:#fff;}
.ep-card .ep-cat{font-size:11px;font-weight:600;color:var(--sub);margin-bottom:7px;letter-spacing:-.005em;}
.ep-card .ep-title{font-size:14px;font-weight:700;line-height:1.4;letter-spacing:-.022em;color:var(--text);margin:0 0 8px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}
.ep-card .ep-meta{font-size:11px;color:var(--sub);letter-spacing:-.005em;}

/* 공개 예정 표 */
.gtable{margin-top:8px;}
.gtable .grow{display:grid;grid-template-columns:60px 1fr;gap:16px;align-items:center;padding:14px 4px;border-top:1px solid var(--hair);}
.gtable .gnum{font:700 12px/1 var(--sans);letter-spacing:-.01em;color:var(--sub2);font-variant-numeric:tabular-nums;}
.gtable .gbody{display:grid;grid-template-columns:24px 1fr;gap:14px;align-items:center;min-width:0;}
.gtable .gflag{width:22px;height:22px;border-radius:50%;box-shadow:0 0 0 1px rgba(0,0,0,.06),0 1px 3px rgba(0,0,0,.1);}
.gtable .gnm{font-weight:700;font-size:14.5px;letter-spacing:-.018em;color:var(--text);}
.gtable .gnm .grp{font-weight:600;font-size:12px;color:var(--sub);margin-left:8px;letter-spacing:-.005em;}

/* aria-disabled (에피소드 상세 페이지 미도입) */
.series-hero[aria-disabled="true"],.ep-card[aria-disabled="true"]{cursor:default;pointer-events:none;}

/* 시리즈 페이지 00화 여는 글 (다크 카드) */
.opening-banner{display:grid;grid-template-columns:auto 1fr auto;gap:22px;align-items:center;background:var(--text);color:#fff;border-radius:4px;padding:20px 24px;margin-bottom:36px;text-decoration:none;transition:transform .25s,background .2s;}
.opening-banner:hover{transform:translateY(-1px);background:#000;}
.opening-banner .ob-mark{font:700 10.5px/1 var(--sans);letter-spacing:-.005em;color:rgba(255,255,255,.55);font-variant-numeric:tabular-nums;display:flex;align-items:center;gap:9px;}
.opening-banner .ob-mark b{font-size:13px;color:#fff;letter-spacing:-.005em;}
.opening-banner .ob-mark .div{width:1px;height:13px;background:rgba(255,255,255,.25);}
.opening-banner .ob-body{min-width:0;}
.opening-banner .ob-title{font-size:17px;font-weight:700;line-height:1.36;letter-spacing:-.025em;margin:0;color:#fff;word-break:keep-all;overflow-wrap:anywhere;}
.opening-banner .ob-sub{font-size:12px;line-height:1.4;color:rgba(255,255,255,.6);margin-top:5px;letter-spacing:-.005em;}
.opening-banner .ob-arrow{font-size:18px;font-weight:300;opacity:.65;transition:transform .2s,opacity .2s;}
.opening-banner:hover .ob-arrow{transform:translateX(3px);opacity:1;}
.opening-banner[aria-disabled="true"]{cursor:default;pointer-events:none;}

/* 매거진 에피소드 상세 — Shadow DOM 호스트 */
/* 페이지 헤더(.detail-head) 없는 매거진 에피소드 상세 — 상단 sticky cond-head(52px) 아래에서 본문 시작. */
.article-view{padding:60px 0;}
.av-host{display:block;width:100%;background:#fff;border-radius:4px;overflow:hidden;}
.av-loading{display:flex;align-items:center;justify-content:center;min-height:40vh;color:var(--sub);font-size:14px;letter-spacing:-.01em;padding:40px 20px;text-align:center;}
