/* /t/css/competition_info.css */
:root{
  --yellow:#FFC000;
  --line:#e9ecf2;
  --text:#121826;
  --sub:#6b7280;
  --green:#16a34a;
  --red:#ef4444;
  --shadow:0 10px 26px rgba(17,24,39,.08);
  --r20:20px;
}

/* 템플릿 container 안에서 쓰도록 */
.nb-page{
  max-width: 800px;
  margin: 0 auto;
}

/* ===== hero ===== */
.hero{
  background:linear-gradient(180deg, #fff 0%, #fff 60%, rgba(255,192,0,.08) 100%);
  border:1px solid var(--line);
  border-radius:var(--r20);
  box-shadow:var(--shadow);
  overflow:hidden;
}
.heroTop{
  padding:16px 16px 12px;
  display:flex;
  gap:14px;
  align-items:flex-start;
}
.poster{
  width:92px; height:92px;
  border-radius:16px;
  overflow:hidden;
  background:#f1f3f8;
  border:1px solid var(--line);
  flex:0 0 auto;
  display:grid;
  place-items:center;
  color:var(--sub);
  font-weight:900;
  font-size:12px;
}
.poster img{width:100%;height:100%;object-fit:cover;display:block;}

.heroInfo{flex:1; min-width:0;}
.titleRow{display:flex; gap:10px; align-items:center;}
.tName{
  margin:0;
  font-size:18px;
  font-weight:1000;
  letter-spacing:-.2px;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.chips{display:flex; gap:6px; flex-wrap:wrap; margin-top:10px;}
.chip{
  display:inline-flex;
  align-items:center;
  padding:7px 10px;
  border-radius:999px;
  font-weight:900;
  font-size:12px;
  border:1px solid var(--line);
  background:#fff;
  color:var(--text);
}
.chip.yellow{border-color:rgba(255,192,0,.45); background:rgba(255,192,0,.14);}
.chip.blue{border-color:rgba(37,99,235,.22); background:rgba(37,99,235,.08); color:#1e3a8a;}
.chip.green{border-color:rgba(22,163,74,.22); background:rgba(22,163,74,.08); color:#14532d;}

.meta{
  margin-top:10px;
  color:var(--sub);
  font-size:13px;
  line-height:1.45;
}
.meta b{color:var(--text);}

/* ===== CTA ===== */
.ctaBar{
  margin-top:14px;
  background:linear-gradient(180deg, rgba(255,192,0,.14), #fff 55%);
  border:1px solid rgba(255,192,0,.30);
  border-radius:18px;
  box-shadow: var(--shadow);
  padding:14px 14px;
  display:flex;
  align-items:center;
  gap:12px;
}
.ctaTitle{font-weight:1000; color:var(--text); letter-spacing:-.2px; line-height:1.15;}
.ctaSub{margin-top:3px; color:var(--sub); font-size:12px; line-height:1.2;}
.ctaBtn{
  margin-left:auto;
  border:0;
  border-radius:14px;
  padding:11px 14px;
  font-weight:1000;
  background: var(--yellow);
  color:#111;
  cursor:pointer;
  white-space:nowrap;
  box-shadow: 0 10px 18px rgba(255,192,0,.22);
}
.ctaBtn:active{ transform:scale(.99); }
.ctaBar[hidden]{ display:none !important; }

/* ===== LIVE ===== */
.liveBar{
  margin:14px 0 0;
  background:#fff;
  border:1px solid rgba(22,163,74,.25);
  border-left:6px solid var(--green);
  border-radius:16px;
  padding:12px 14px;
  box-shadow:var(--shadow);
  display:flex;
  align-items:center;
  gap:10px;
}
.liveDot{
  width:10px;height:10px;border-radius:999px;
  background:var(--red);
  box-shadow:0 0 0 4px rgba(239,68,68,.12);
  flex:0 0 auto;
}
.liveTitle{font-weight:1000; letter-spacing:-.2px;}
.liveSub{
  color:var(--sub);
  font-size:13px;
  margin-left:auto;
  display:flex; align-items:center; gap:8px;
}
.pill{
  min-width:26px;
  height:22px;
  padding:0 8px;
  border-radius:999px;
  font-weight:1000;
  font-size:12px;
  background:rgba(22,163,74,.10);
  border:1px solid rgba(22,163,74,.22);
  color:#14532d;
  display:inline-flex;
  align-items:center;
  justify-content:center;
}
.liveBar[hidden]{display:none;}

/* ===== grid ===== */
.grid{
  margin-top:14px;
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:12px;
}
.card{
  background:#fff;
  border:1px solid var(--line);
  border-radius:18px;
  box-shadow:var(--shadow);
  padding:14px;
  display:flex;
  gap:12px;
  align-items:center;
  cursor:pointer;
}
.card:active{transform:scale(.99);}
.ic{
  width:44px;height:44px;border-radius:14px;
  display:grid;place-items:center;
  background:rgba(255,192,0,.14);
  border:1px solid rgba(255,192,0,.28);
  font-size:22px;
  flex:0 0 auto;
}
.card h3{margin:0; font-size:15px; font-weight:1000; letter-spacing:-.2px;}
.card p{margin:4px 0 0; color:var(--sub); font-size:12px; line-height:1.25;}
.card.result, .progress, .players, .bracket{
  background:linear-gradient(180deg, rgba(255,192,0,.10), #fff 38%);
}
.card.progress .ic{background:rgba(37,99,235,.10); border-color:rgba(37,99,235,.22);}
.card.players .ic{background:rgba(22,163,74,.10); border-color:rgba(22,163,74,.22);}
.card.result .ic{background:rgba(255,192,0,.18); border-color:rgba(255,192,0,.35);}

/* ===== tabs/panel ===== */
.tabs{
  margin-top:14px;
  display:flex;
  background:#fff;
  border:1px solid var(--line);
  border-radius:16px;
  overflow:hidden;
  box-shadow:var(--shadow);
}
.tab{
  flex:1;
  border:0;
  background:transparent;
  padding:12px 10px;
  font-weight:1000;
  color:var(--sub);
  cursor:pointer;
  display:flex; align-items:center; justify-content:center; gap:8px;
}
.tab.active{color:#111; background:rgba(255,192,0,.18);}

.panel{
  margin-top:10px;
  background:#fff;
  border:1px solid var(--line);
  border-radius:16px;
  box-shadow:var(--shadow);
  padding:14px;
  color:var(--sub);
  font-size:13px;
  line-height:1.6;
}
.panelTitle{font-weight:1000; color:#111;}
.kv{
  display:grid;
  grid-template-columns:92px 1fr;
  gap:8px 10px;
  margin-top:10px;
}
.kv b{color:var(--text);}

.descBox{margin-top:12px;}
.descTitle{font-weight:1000; color:#111; margin-bottom:6px;}
.descText{color:var(--sub);}

.pillRow{display:flex; gap:10px; flex-wrap:wrap; margin-top:10px;}
.linkChip{
  border:1px solid var(--line);
  background:#fff;
  border-radius:999px;
  padding:10px 12px;
  font-weight:1000;
  cursor:pointer;
}
.linkChip:active{transform:scale(.99);}

/* poster large */
.posterLargeWrap{margin-top:18px;}
.posterLargeTitle{font-weight:1000;color:#111;margin-bottom:8px;}
.posterLargeBox{
  width:100%;
  border-radius:16px;
  overflow:hidden;
  border:1px solid #E9ECF2;
  background:#fff;
  box-shadow:0 8px 20px rgba(0,0,0,0.06);
}
.posterLargeBox img{width:100%;height:auto;display:block;object-fit:contain;}

/* guide modal */
.backdrop{
  position:fixed; inset:0; background:rgba(0,0,0,.45);
  display:flex; align-items:center; justify-content:center; z-index:9999;
  padding:0;
}
#guideModal{display:none;}
#guideModal .guideSheet{
  width:100%;
  height:100dvh;
  background:#fff;
  border-radius:0;
  overflow:hidden;
  display:flex;
  flex-direction:column;
  padding-top: env(safe-area-inset-top);
  padding-bottom: env(safe-area-inset-bottom);
}
#guideModal .modalHead{
  display:flex; align-items:center; justify-content:space-between;
  padding:12px 14px; border-bottom:1px solid #eee;
}
#guideModal .closeX{
  border:0; background:transparent; font-size:18px; font-weight:900; cursor:pointer;
}
#guideModal .modalBody{flex:1; padding:0; overflow:hidden;}
#guideFrame{width:100%; height:100%; border:0; display:block;}

@media (max-width:380px){
  .poster{width:84px;height:84px;}
  .tName{font-size:17px;}
}
@media (max-width:420px){
  .ctaBar{ align-items:flex-start; }
  .ctaBtn{ padding:10px 12px; }
}