:root{--bg:#08080b;--surf:#111116;--surf2:#18181f;--gold:#c8860e;--gold2:#f0aa20;--silver:#9a9aaa;--text:#f0f0f4;--dim:#66667a;--border:#222230;--green:#22c55e;--r:14px}
*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
html,body{height:100%;background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;overflow:hidden}
#app{height:100dvh;display:flex;flex-direction:column;max-width:520px;margin:0 auto;width:100%}
.screen{display:flex;flex-direction:column;height:100%;overflow:hidden}
.screen.hidden{display:none!important}

/* BUTTONS */
.btn{padding:14px 24px;border-radius:12px;border:none;font-size:16px;font-weight:700;cursor:pointer;transition:transform .1s,opacity .1s;letter-spacing:.2px;width:100%}
.btn:active{transform:scale(.97);opacity:.9}
.btn-gold{background:var(--gold);color:#000}
.btn-dim{background:var(--surf2);color:var(--text);border:1px solid var(--border)}
.btn-back{background:none;border:none;color:var(--dim);font-size:15px;cursor:pointer;padding:8px 4px;width:auto}
.btn-icon{background:none;border:none;color:var(--dim);font-size:22px;cursor:pointer;padding:8px;line-height:1;width:auto}
.btn-undo{background:none;border:none;font-size:22px;cursor:pointer;padding:8px;line-height:1;width:auto;transition:opacity .2s;color:var(--gold)}
.btn-undo.hidden{opacity:0;pointer-events:none}

/* HOME */
#screen-home{justify-content:center;align-items:center;gap:24px;padding:40px 28px}
.home-logo{font-size:60px;animation:pulse 2.5s ease-in-out infinite}
@keyframes pulse{0%,100%{transform:scale(1)}50%{transform:scale(1.1)}}
.home-title{font-size:34px;font-weight:900;text-align:center;line-height:1.15;letter-spacing:-1px}
.home-title span{display:block;font-size:14px;font-weight:700;color:var(--gold);letter-spacing:3px;text-transform:uppercase;margin-top:8px}
.home-resume{background:var(--surf2);border:1px solid var(--border);border-radius:var(--r);padding:18px 20px;width:100%;max-width:360px;display:flex;flex-direction:column;gap:10px;align-items:center}
.resume-label{font-size:11px;text-transform:uppercase;letter-spacing:1px;color:var(--gold);font-weight:700}
.resume-info{font-size:14px;color:var(--dim)}
.home-actions{display:flex;flex-direction:column;gap:10px;width:100%;max-width:360px}
.home-games{font-size:13px;color:var(--dim)}

/* FACE-OFF */
#screen-faceoff{overflow:hidden}
.faceoff-header{display:flex;justify-content:space-between;align-items:center;padding:10px 12px 4px;flex-shrink:0}
.faceoff-round{font-size:12px;font-weight:700;color:var(--dim);text-transform:uppercase;letter-spacing:.8px;text-align:center;flex:1}
.faceoff-progress{display:flex;align-items:center;gap:10px;padding:0 14px 6px;flex-shrink:0}
.progress-bar{flex:1;height:3px;background:var(--surf2);border-radius:2px;overflow:hidden}
.progress-fill{height:100%;background:var(--gold);border-radius:2px;transition:width .4s ease}
.progress-text{font-size:11px;color:var(--dim);white-space:nowrap}
.faceoff-cards{flex:1;display:flex;flex-direction:column;gap:8px;padding:0 8px;min-height:0}


/* CARDS — horizontal full-bleed with overlay name */
.card{flex:1;border-radius:var(--r);overflow:hidden;cursor:pointer;position:relative;border:2px solid var(--border);min-height:0;-webkit-user-select:none;user-select:none;transition:border-color .15s}
.card:active{opacity:.92}
.card-bg{position:absolute;inset:0;display:flex;align-items:center;justify-content:center}
.card-photo{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:top center;z-index:1}
.card-initials{font-size:44px;font-weight:900;color:rgba(255,255,255,.18);letter-spacing:-1px;pointer-events:none;z-index:0;position:relative}
.card-name{position:absolute;bottom:0;left:0;right:0;padding:12px 16px 10px;font-size:20px;font-weight:800;text-align:center;background:linear-gradient(to top,rgba(0,0,0,.88) 0%,rgba(0,0,0,.5) 55%,transparent 100%);color:#fff;z-index:2;text-shadow:0 1px 4px rgba(0,0,0,.6);line-height:1.2}

/* CARD ANIMATIONS */
.card.slide-in{animation:slideIn .25s ease-out}
@keyframes slideIn{from{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}
.card.winner-flash{animation:winFlash .5s ease-out forwards;border-color:var(--gold)!important}
@keyframes winFlash{0%{transform:scale(1)}35%{transform:scale(1.025)}100%{transform:scale(1)}}
.card.loser-fade{animation:loseFade .5s ease-out forwards}
@keyframes loseFade{to{opacity:.18;transform:scale(.97)}}

/* VICTORY */
#screen-victory{justify-content:center;align-items:center;gap:14px;padding:28px 28px;overflow-y:auto}
.victory-crown{font-size:48px;animation:pulse 2s infinite}
.victory-label{font-size:13px;font-weight:700;color:var(--gold);text-transform:uppercase;letter-spacing:2px}
.victory-card{width:min(340px,88vw);aspect-ratio:4/3;border-radius:var(--r);overflow:hidden;border:3px solid var(--gold);box-shadow:0 0 60px rgba(200,134,14,.5);flex-shrink:0;position:relative}
.victory-card .card-bg{position:absolute;inset:0}
.victory-name{font-size:26px;font-weight:900;text-align:center;letter-spacing:-.5px}
.victory-games{font-size:13px;color:var(--dim)}
.victory-actions{display:flex;gap:10px;width:100%;max-width:320px}
.victory-actions .btn{flex:1;padding:13px 16px}

/* SHARED SCREENS */
.screen-header{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;border-bottom:1px solid var(--border);flex-shrink:0}
.screen-header h2{font-size:17px;font-weight:700}
.list-body{flex:1;overflow-y:auto;padding:10px}

/* LEAGUE */
.league-row{display:flex;align-items:center;gap:12px;padding:11px 14px;border-radius:10px;margin-bottom:5px;background:var(--surf)}
.league-row.r1{background:linear-gradient(135deg,rgba(200,134,14,.22) 0%,var(--surf) 100%);border:1px solid rgba(200,134,14,.25)}
.league-row.r2{background:linear-gradient(135deg,rgba(154,154,170,.15) 0%,var(--surf) 100%)}
.league-row.r3{background:linear-gradient(135deg,rgba(180,100,40,.15) 0%,var(--surf) 100%)}
.league-pos{font-size:18px;width:28px;text-align:center;flex-shrink:0}
.league-name{flex:1;font-size:14px;font-weight:600;line-height:1.2}
.league-pts{font-size:18px;font-weight:900;color:var(--gold)}

/* BRACKET */
.bracket-section{margin-bottom:20px}
.bracket-section h3{font-size:11px;font-weight:700;color:var(--gold);text-transform:uppercase;letter-spacing:1.2px;margin-bottom:8px;padding:0 4px}
.bracket-round{margin-bottom:10px}
.bracket-round-label{font-size:10px;color:var(--dim);text-transform:uppercase;letter-spacing:.6px;font-weight:700;margin-bottom:5px;padding:0 2px}
.bm{background:var(--surf2);border-radius:8px;padding:8px 11px;margin-bottom:3px;font-size:13px;border-left:3px solid transparent}
.bm.done{border-left-color:var(--green)}.bm.live{border-left-color:var(--gold)}.bm.future{color:var(--dim);border-left-color:var(--border)}
.bm .w{font-weight:700;color:var(--green)}.bm .vs{color:var(--dim);font-size:11px;padding:0 4px}
.bm.champion{border-left-color:var(--gold)}.bm.champion .w{color:var(--gold)}
.empty-state{text-align:center;padding:40px 20px;color:var(--dim);font-size:15px}
::-webkit-scrollbar{width:3px}::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}
.hidden{display:none!important}
/* FACEOFF FOOTER — undo lives here, below cards */
.faceoff-footer{display:flex;align-items:center;justify-content:center;padding:6px 12px;flex-shrink:0;min-height:38px}
.btn-undo{background:none;border:1px solid var(--gold);border-radius:8px;color:var(--gold);font-size:13px;font-weight:700;cursor:pointer;padding:6px 14px;transition:opacity .2s,background .15s;letter-spacing:.3px}
.btn-undo:active{background:rgba(200,134,14,.15)}
.btn-undo.hidden{display:none}
.faceoff-hint{font-size:12px;color:var(--dim)}
/* HEADER buttons */
.btn-hdr{background:none;border:none;color:var(--dim);font-size:22px;cursor:pointer;padding:8px;line-height:1;width:40px;text-align:center}
.btn-hdr:active{color:var(--text)}
/* remove old faceoff-hint standalone rule handled in footer now */
.card-season{position:absolute;top:6px;right:6px;z-index:3;background:rgba(0,0,0,.72);color:rgba(255,255,255,.9);font-size:9px;font-weight:800;padding:2px 5px;border-radius:4px;letter-spacing:.5px;pointer-events:none}
.card-season.bbcan{background:rgba(160,20,20,.85)}
