/* TEAM ENDURANCE — volt dark, high-density design system */
@import url("https://cdn.jsdelivr.net/gh/orioncactus/pretendard@v1.3.9/dist/web/static/pretendard.css");

:root{
  --bg:#0b0d11; --bg2:#0f1218; --panel:#14181f; --panel2:#181d26; --elev:#1d2330;
  --line:#242c38; --line2:#2e3744;
  --tx:#e9eef6; --tx2:#9aa6b6; --tx3:#6b7686;
  --volt:#c8f23c; --volt-d:#a9d420; --cyan:#33e1d6; --coral:#ff6a5a; --gold:#ffcd4d;
  --steel:#5b8def; --posco:#3f6fd6;
  --r:12px; --r2:9px; --gap:12px;
  --shadow:0 1px 0 rgba(255,255,255,.02), 0 8px 24px rgba(0,0,0,.35);
  --glow:0 0 0 1px rgba(200,242,60,.25), 0 6px 22px rgba(200,242,60,.08);
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{
  font-family:"Pretendard","Pretendard Variable",system-ui,-apple-system,"Segoe UI",sans-serif;
  background:
    radial-gradient(1200px 600px at 80% -10%, rgba(51,225,214,.06), transparent 60%),
    radial-gradient(900px 500px at -10% 10%, rgba(200,242,60,.06), transparent 55%),
    var(--bg);
  color:var(--tx); font-size:13.5px; line-height:1.45; letter-spacing:-.01em;
  -webkit-font-smoothing:antialiased;
}
a{color:inherit;text-decoration:none}
::-webkit-scrollbar{width:9px;height:9px}
::-webkit-scrollbar-thumb{background:#262e3b;border-radius:8px}
::-webkit-scrollbar-thumb:hover{background:#334050}

/* ---------- layout ---------- */
.app{display:grid;grid-template-columns:212px 1fr;min-height:100vh}
.sidebar{
  position:sticky;top:0;height:100vh;background:linear-gradient(180deg,var(--bg2),var(--bg));
  border-right:1px solid var(--line);display:flex;flex-direction:column;padding:14px 10px;gap:4px;
}
.brand{display:flex;align-items:center;gap:9px;padding:6px 8px 12px}
.brand .logo{
  width:34px;height:34px;border-radius:9px;flex:none;
  background:linear-gradient(135deg,var(--volt),var(--cyan));
  display:grid;place-items:center;color:#06210a;font-weight:900;font-size:17px;
  box-shadow:0 4px 14px rgba(200,242,60,.3);
}
.brand b{font-size:14.5px;font-weight:800;letter-spacing:.02em;line-height:1.1}
.brand small{display:block;color:var(--tx3);font-size:10.5px;font-weight:600;letter-spacing:.04em}
.nav{display:flex;flex-direction:column;gap:2px;margin-top:4px}
.nav a{
  display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:9px;
  color:var(--tx2);font-weight:600;font-size:13px;transition:.12s;
}
.nav a .ic{width:18px;text-align:center;font-size:14px;filter:grayscale(.2)}
.nav a:hover{background:var(--panel);color:var(--tx)}
.nav a.on{background:linear-gradient(90deg,rgba(200,242,60,.16),rgba(200,242,60,.04));color:var(--volt)}
.nav a.on .ic{filter:none}
.side-foot{margin-top:auto;border-top:1px solid var(--line);padding:10px 8px 2px;color:var(--tx3);font-size:11px}
.side-foot .sync{display:flex;align-items:center;gap:6px;color:var(--tx2);font-weight:600;margin-bottom:6px}
.dot{width:7px;height:7px;border-radius:50%;background:var(--volt);box-shadow:0 0 8px var(--volt);animation:pulse 2s infinite}
@keyframes pulse{50%{opacity:.4}}

.main{min-width:0;display:flex;flex-direction:column}
.topbar{
  position:sticky;top:0;z-index:20;display:flex;align-items:center;gap:14px;
  padding:11px 20px;background:rgba(11,13,17,.82);backdrop-filter:blur(12px);
  border-bottom:1px solid var(--line);
}
.topbar h1{font-size:16px;font-weight:800;letter-spacing:-.02em}
.topbar .sub{color:var(--tx3);font-size:11.5px;font-weight:600}
.spacer{flex:1}
.t-chip{
  display:flex;align-items:center;gap:7px;background:var(--panel);border:1px solid var(--line);
  padding:6px 11px;border-radius:20px;font-size:12px;font-weight:600;color:var(--tx2);
}
.t-chip b{color:var(--tx)}
.me{display:flex;align-items:center;gap:8px;padding:4px 4px 4px 11px;background:var(--panel);border:1px solid var(--line);border-radius:22px;font-size:12px;font-weight:700}
.content{padding:18px 20px 40px;max-width:1480px;width:100%}

/* ---------- hero stat strip ---------- */
.hero{display:grid;grid-template-columns:repeat(6,1fr);gap:var(--gap);margin-bottom:var(--gap)}
.stat{
  background:linear-gradient(160deg,var(--panel2),var(--panel));border:1px solid var(--line);
  border-radius:var(--r);padding:13px 14px;position:relative;overflow:hidden;
}
.stat::after{content:"";position:absolute;inset:0;background:radial-gradient(120px 60px at 90% 0%,rgba(200,242,60,.10),transparent 70%)}
.stat .k{font-size:11px;color:var(--tx3);font-weight:700;letter-spacing:.02em;display:flex;align-items:center;gap:5px}
.stat .v{font-size:25px;font-weight:900;letter-spacing:-.03em;margin-top:3px;font-variant-numeric:tabular-nums}
.stat .v small{font-size:13px;font-weight:700;color:var(--tx2);margin-left:2px}
.stat .d{font-size:11px;font-weight:700;margin-top:2px}
.up{color:var(--volt)} .down{color:var(--coral)}
.stat.accent{background:linear-gradient(150deg,rgba(200,242,60,.16),rgba(51,225,214,.06));border-color:rgba(200,242,60,.3)}
.stat.accent .v{color:var(--volt)}

/* ---------- bento grid ---------- */
.grid{display:grid;grid-template-columns:repeat(12,1fr);gap:var(--gap);align-items:start}
.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--shadow);overflow:hidden}
.card>.hd{display:flex;align-items:center;gap:8px;padding:11px 13px 9px;border-bottom:1px solid var(--line)}
.card>.hd h3{font-size:13px;font-weight:800;letter-spacing:-.01em;display:flex;align-items:center;gap:7px}
.card>.hd .more{margin-left:auto;color:var(--tx3);font-size:11.5px;font-weight:700}
.card>.hd .more:hover{color:var(--volt)}
.card .bd{padding:8px 13px 12px}
.col-3{grid-column:span 3}.col-4{grid-column:span 4}.col-5{grid-column:span 5}
.col-6{grid-column:span 6}.col-7{grid-column:span 7}.col-8{grid-column:span 8}.col-12{grid-column:span 12}

/* ---------- generic bits ---------- */
.chip{display:inline-flex;align-items:center;gap:4px;font-size:10.5px;font-weight:800;padding:2px 7px;border-radius:7px;letter-spacing:.01em}
.chip.all{background:rgba(200,242,60,.14);color:var(--volt)}
.chip.posco{background:rgba(63,111,214,.18);color:#9bb8ff}
.chip.mm{background:rgba(255,205,77,.16);color:var(--gold)}
.chip.race{background:rgba(255,106,90,.16);color:var(--coral)}
.chip.flash{background:rgba(51,225,214,.15);color:var(--cyan)}
.chip.ghost{background:var(--elev);color:var(--tx2)}
.av{width:30px;height:30px;border-radius:9px;flex:none;display:grid;place-items:center;font-weight:800;font-size:11px;color:#0a0c10}
.btn{display:inline-flex;align-items:center;gap:6px;background:var(--elev);border:1px solid var(--line2);color:var(--tx);font-weight:700;font-size:12px;padding:6px 11px;border-radius:8px;cursor:pointer;transition:.12s}
.btn:hover{border-color:var(--volt);color:var(--volt)}
.btn.go{background:var(--volt);color:#0a1605;border-color:var(--volt)}
.btn.go:hover{filter:brightness(1.08);color:#0a1605}
.muted{color:var(--tx3)}.tnum{font-variant-numeric:tabular-nums}

/* ---------- leaderboard ---------- */
.rank{display:flex;align-items:center;gap:10px;padding:7px 4px;border-bottom:1px solid var(--line)}
.rank:last-child{border-bottom:0}
.rank .no{width:22px;text-align:center;font-weight:900;font-size:13px;color:var(--tx3);font-variant-numeric:tabular-nums}
.rank.top1 .no{color:var(--gold)}.rank.top2 .no{color:#cdd6e2}.rank.top3 .no{color:#e1944f}
.rank .nm{font-weight:700;font-size:13px}
.rank .meta{color:var(--tx3);font-size:11px;font-weight:600}
.rank .km{margin-left:auto;text-align:right;font-weight:900;font-size:14px;font-variant-numeric:tabular-nums}
.rank .km small{display:block;color:var(--tx3);font-size:10px;font-weight:700}
.bar{height:4px;border-radius:3px;background:var(--line);overflow:hidden;margin-top:4px}
.bar>i{display:block;height:100%;background:linear-gradient(90deg,var(--volt),var(--cyan))}

/* ---------- events ---------- */
.ev{display:flex;gap:11px;padding:9px 4px;border-bottom:1px solid var(--line)}
.ev:last-child{border-bottom:0}
.ev .date{width:46px;flex:none;text-align:center;background:var(--elev);border:1px solid var(--line);border-radius:9px;padding:5px 0}
.ev .date .d{font-size:17px;font-weight:900;line-height:1}.ev .date .m{font-size:10px;color:var(--tx3);font-weight:700}
.ev .info{min-width:0;flex:1}
.ev .info .t{font-weight:700;font-size:13px}
.ev .info .ln{color:var(--tx2);font-size:11.5px;font-weight:600;display:flex;gap:8px;flex-wrap:wrap;margin-top:2px}
.ev .rsvp{margin-left:auto;text-align:right;flex:none}
.ev .rsvp .n{font-weight:900;font-size:14px;color:var(--volt)}.ev .rsvp .n small{color:var(--tx3);font-weight:700;font-size:10px}

/* ---------- announcements ---------- */
.ann{padding:9px 4px;border-bottom:1px solid var(--line)}.ann:last-child{border-bottom:0}
.ann .t{font-weight:700;font-size:13px;display:flex;align-items:center;gap:7px}
.ann .b{color:var(--tx2);font-size:11.5px;margin-top:3px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.ann .mt{color:var(--tx3);font-size:10.5px;font-weight:600;margin-top:4px}
.pin{color:var(--volt)}

/* ---------- feed ---------- */
.fd{display:flex;gap:10px;padding:9px 4px;border-bottom:1px solid var(--line)}.fd:last-child{border-bottom:0}
.fd .info{flex:1;min-width:0}
.fd .top{display:flex;align-items:center;gap:7px;font-size:12px}
.fd .top b{font-weight:700}.fd .top .g{font-size:10px;color:var(--cyan);font-weight:800;border:1px solid rgba(51,225,214,.3);padding:0 5px;border-radius:6px}
.fd .t{font-weight:700;font-size:13px;margin-top:2px}
.fd .row{display:flex;gap:12px;margin-top:4px;font-size:11.5px;color:var(--tx2);font-weight:700}
.fd .row b{color:var(--tx)}
.fd .react{display:flex;gap:12px;margin-top:5px;font-size:11.5px;color:var(--tx3);font-weight:700}
.fd .react span:hover{color:var(--volt);cursor:pointer}

/* ---------- poll ---------- */
.poll{padding:9px 2px;border-bottom:1px solid var(--line)}.poll:last-child{border-bottom:0}
.poll .q{font-weight:700;font-size:12.5px;margin-bottom:6px;display:flex;gap:7px}
.opt{position:relative;border:1px solid var(--line);border-radius:8px;padding:5px 9px;margin-bottom:4px;cursor:pointer;overflow:hidden;font-size:12px;font-weight:600;display:flex;justify-content:space-between}
.opt .fill{position:absolute;inset:0;background:rgba(200,242,60,.12);z-index:0}
.opt span{position:relative;z-index:1}.opt b{position:relative;z-index:1;color:var(--volt)}
.opt:hover{border-color:var(--volt-d)}

/* ---------- goods / badges ---------- */
.gd{display:flex;gap:10px;padding:9px 2px;border-bottom:1px solid var(--line)}.gd:last-child{border-bottom:0}
.gd .thumb{width:42px;height:42px;border-radius:9px;background:linear-gradient(135deg,var(--elev),#222a38);display:grid;place-items:center;font-size:18px;flex:none}
.gd .info{flex:1;min-width:0}.gd .t{font-weight:700;font-size:12.5px}.gd .v{color:var(--tx3);font-size:11px;font-weight:600}
.gd .prog{display:flex;align-items:center;gap:8px;margin-top:4px}
.gd .prog .bar{flex:1;margin:0}.gd .prog .n{font-size:11px;font-weight:800;color:var(--volt)}
.hof{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.medal{background:var(--elev);border:1px solid var(--line);border-radius:10px;padding:9px 10px}
.medal .k{font-size:10.5px;color:var(--tx3);font-weight:800;letter-spacing:.02em}
.medal .m{font-weight:800;font-size:13px;margin-top:1px}
.medal .dt{color:var(--tx3);font-size:10.5px;font-weight:600;margin-top:1px}

/* ---------- race tiles ---------- */
.race{display:flex;align-items:center;gap:9px;padding:8px 2px;border-bottom:1px solid var(--line)}.race:last-child{border-bottom:0}
.race .dd{flex:none;width:50px;text-align:center;background:rgba(255,106,90,.12);border:1px solid rgba(255,106,90,.25);border-radius:9px;padding:5px 0}
.race .dd b{display:block;font-size:14px;font-weight:900;color:var(--coral);line-height:1}.race .dd small{font-size:9px;color:var(--tx3);font-weight:700}
.race .nm{font-weight:700;font-size:12.5px}.race .mt{color:var(--tx3);font-size:11px;font-weight:600}

/* ---------- simple page table ---------- */
.list{display:flex;flex-direction:column}
.list .li{display:flex;align-items:center;gap:12px;padding:11px 4px;border-bottom:1px solid var(--line)}
.list .li:hover{background:var(--panel2)}

/* ---------- interactive states ---------- */
[data-kudos],[data-vote]{cursor:pointer;user-select:none}
.react [data-kudos]:hover{color:var(--volt)}
.react .liked,[data-kudos].liked{color:var(--coral)!important}
.btn.go.done{background:var(--elev);color:var(--volt);border-color:var(--volt)}
.opt[data-vote]:hover{border-color:var(--volt)}
.opt.picked b{color:var(--volt)}
.opt.picked{box-shadow:0 0 0 1px var(--volt-d) inset}

/* ---------- garmin real media ---------- */
img.av{object-fit:cover;background:#222}
.fd-photo{display:block;margin-top:7px;width:100%;max-width:300px;max-height:180px;object-fit:cover;border-radius:10px;border:1px solid var(--line)}
.gbadge{display:inline-flex;align-items:center;gap:4px;font-size:10px;font-weight:800;color:var(--cyan);border:1px solid rgba(51,225,214,.3);padding:0 5px;border-radius:6px}

/* ---------- hero banner (대문) ---------- */
.herobanner{position:relative;border-radius:var(--r);overflow:hidden;margin-bottom:var(--gap);min-height:188px;display:flex;align-items:flex-end;background-size:cover;background-position:center 38%;border:1px solid var(--line)}
.herobanner.noimg{background:linear-gradient(135deg,#16242e,#0f1620)}
.hb-ov{position:absolute;inset:0;background:linear-gradient(180deg,rgba(8,10,14,.05),rgba(8,10,14,.5) 55%,rgba(8,10,14,.93))}
.hb-c{position:relative;padding:18px 22px;width:100%}
.hb-t{font-size:31px;font-weight:900;letter-spacing:-.02em;line-height:1;text-shadow:0 2px 14px rgba(0,0,0,.6)}
.hb-t b{color:var(--volt)}
.hb-s{color:#d3dbe5;font-size:12.5px;font-weight:600;margin-top:7px;text-shadow:0 1px 8px rgba(0,0,0,.7)}
.hb-stats{display:flex;gap:24px;margin-top:13px}
.hb-stats>div{display:flex;flex-direction:column}
.hb-stats b{font-size:21px;font-weight:900;color:#fff;font-variant-numeric:tabular-nums;line-height:1}
.hb-stats b small{font-size:11px;color:#aeb8c4;font-weight:700}
.hb-stats span{font-size:10.5px;color:#aeb8c4;font-weight:700;margin-top:2px}
.hb-edit{position:absolute;top:12px;right:13px;background:rgba(8,10,14,.45);border:1px solid rgba(255,255,255,.16);color:#dfe6ee;font-size:11px;font-weight:700;padding:4px 11px;border-radius:20px;backdrop-filter:blur(5px)}
.hb-edit:hover{color:var(--volt);border-color:var(--volt)}

/* ---------- leaderboard period tabs ---------- */
.lb-tabs{display:flex;gap:3px;margin-bottom:9px;background:var(--bg2);border:1px solid var(--line);border-radius:9px;padding:3px}
.lb-tabs button{flex:1;background:transparent;border:0;color:var(--tx2);font-weight:800;font-size:11.5px;padding:5px 0;border-radius:7px;cursor:pointer;transition:.1s}
.lb-tabs button.on{background:var(--volt);color:#0a1605}
.lb-tabs button:hover:not(.on){color:var(--tx)}
.km .kmv{font-variant-numeric:tabular-nums}

/* ---------- PR badge ---------- */
.pr-badge{font-size:9.5px;font-weight:900;color:var(--gold);border:1px solid rgba(255,205,77,.45);padding:0 5px;border-radius:6px;background:rgba(255,205,77,.1)}
.rank.top1 .km .kmv{color:var(--gold)}

/* ---------- admin hero form ---------- */
.fl{display:block;font-size:11.5px;font-weight:700;color:var(--tx2);margin:11px 0 3px}
.fi{width:100%;padding:9px 11px;border-radius:8px;border:1px solid var(--line2);background:var(--bg2);color:var(--tx);font-size:13px}
.fi:focus{outline:none;border-color:var(--volt)}
.photogrid{display:grid;grid-template-columns:repeat(4,1fr);gap:7px}
.photogrid .pick{width:100%;height:66px;object-fit:cover;border-radius:8px;border:2px solid transparent;cursor:pointer;transition:.1s}
.photogrid .pick:hover{border-color:var(--line2)}
.photogrid .pick.sel{border-color:var(--volt)}

@media(max-width:1180px){.hero{grid-template-columns:repeat(3,1fr)}.col-3,.col-4,.col-5{grid-column:span 6}.col-7,.col-8{grid-column:span 12}}
@media(max-width:760px){.app{grid-template-columns:1fr}.sidebar{display:none}.hero{grid-template-columns:repeat(2,1fr)}.grid>*{grid-column:span 12!important}}
