:root{--bg: #0f1419;--surface: #1a2332;--surface-hover: #243044;--border: #2d3a4f;--text: #e7ecf3;--muted: #8b9cb3;--primary: #4f8cff;--primary-hover: #3a7aef;--success: #3dd68c;--error: #ff6b6b;--warning: #ffb347;--radius: 10px;--font: system-ui, -apple-system, "Segoe UI", sans-serif}*{box-sizing:border-box}html,body,#root{width:100%;max-width:100%;overflow-x:hidden}body{margin:0;font-family:var(--font);background:var(--bg);color:var(--text);line-height:1.5}a{color:var(--primary);text-decoration:none}a:hover{text-decoration:underline}.page{width:100%;max-width:none;margin:0;padding:1.5rem clamp(1rem,3vw,2rem)}.page-bracket{min-height:100vh}.host-section{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem 1.5rem}.host-cta{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;flex-wrap:wrap}.host-cta h2{margin:0 0 .35rem;font-size:1.15rem}.lobby-panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.5rem;margin-bottom:2rem}.lobby-panel h2{margin:0 0 1rem;font-size:1.15rem}.participant-list{margin:1rem 0}.participant-list ul{margin:.5rem 0 0;padding-left:1.25rem}.participant-list li{margin-bottom:.25rem}.header{display:flex;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:2rem;flex-wrap:wrap}.header h1{margin:.25rem 0 0;font-size:1.75rem}.header-actions{display:flex;align-items:center;gap:1rem}.back-link{display:inline-block;margin-bottom:.25rem;font-size:.9rem}.user-info{color:var(--muted)}.host-badge{margin-left:.5rem;padding:.15rem .5rem;background:var(--primary);color:#fff;border-radius:4px;font-size:.75rem}.btn{padding:.55rem 1rem;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);color:var(--text);cursor:pointer;font-size:.95rem}.btn:hover{background:var(--surface-hover)}.btn-primary{background:var(--primary);border-color:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-hover)}.btn-small{padding:.35rem .75rem;font-size:.85rem}.btn-danger{background:#ff6b6b1f;border-color:#ff6b6b73;color:var(--error)}.btn-danger:hover{background:#ff6b6b38;border-color:var(--error)}.btn-full{width:100%}.btn:disabled{opacity:.5;cursor:not-allowed}.link-btn{background:none;border:none;color:var(--primary);cursor:pointer;margin-top:1rem;font-size:.9rem}.field{display:flex;flex-direction:column;gap:.35rem;margin-bottom:1rem}.field span{font-size:.85rem;color:var(--muted)}.field input{padding:.6rem .75rem;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg);color:var(--text);font-size:1rem}.checkbox-field{display:flex;align-items:center;gap:.5rem;margin-bottom:1rem}.error{color:var(--error)}.success{color:var(--success)}.muted{color:var(--muted)}.error-list{color:var(--error);padding-left:1.25rem}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:1rem}.auth-card{width:100%;max-width:400px;background:var(--surface);border:1px solid var(--border);border-radius:calc(var(--radius) * 1.5);padding:2rem}.auth-card h1{margin:0;text-align:center}.subtitle{text-align:center;color:var(--muted);margin:.5rem 0 1.5rem}.password-policy{margin:0 0 1rem;padding:.75rem 1rem;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius)}.password-policy__title{margin:0 0 .5rem;font-size:.85rem;font-weight:600}.password-policy__rules{margin:0;padding-left:1.15rem;color:var(--muted);font-size:.85rem}.password-policy__rules li{margin-bottom:.2rem}.section{margin-bottom:2rem}.tournament-list{list-style:none;padding:0;margin:0}.tournament-list li{margin-bottom:.5rem}.tournament-list__item{display:flex;align-items:stretch;gap:.5rem}.tournament-list__item .tournament-link{flex:1;min-width:0}.tournament-list__item .btn-danger{flex:0 0 auto;align-self:stretch}.tournament-link{display:flex;flex-direction:column;padding:1rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);color:var(--text)}.tournament-link:hover{background:var(--surface-hover);text-decoration:none}.tournament-link span{color:var(--muted);font-size:.85rem;margin-top:.25rem}.setup-form{margin-top:1rem;padding:1.5rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius)}.drop-zone{border:2px dashed var(--border);border-radius:var(--radius);padding:2rem;text-align:center;cursor:pointer;margin-bottom:1rem;transition:border-color .2s}.drop-zone:hover{border-color:var(--primary)}.file-count{color:var(--success);margin-top:.5rem}.upload-file-list{margin-bottom:1rem;padding:.85rem 1rem;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius)}.upload-file-list__header{display:flex;align-items:center;justify-content:space-between;gap:.75rem;margin-bottom:.65rem;font-size:.9rem}.upload-file-list__items{margin:0;padding:0;list-style:none;max-height:220px;overflow-y:auto}.upload-file-list__items li{display:flex;align-items:center;gap:.5rem;padding:.35rem 0;border-bottom:1px solid var(--border);font-size:.85rem;font-family:ui-monospace,monospace}.upload-file-list__items li:last-child{border-bottom:none}.upload-file-list__name{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.upload-file-list__remove{flex:0 0 auto;width:1.75rem;height:1.75rem;padding:0;border:1px solid var(--border);border-radius:6px;background:var(--surface);color:var(--muted);font-size:1.1rem;line-height:1;cursor:pointer}.upload-file-list__remove:hover{color:var(--error);border-color:#ff6b6b73;background:#ff6b6b1f}.filename-template{margin-bottom:1.25rem;padding:1rem 1.1rem;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius)}.filename-template h3,.filename-template h4{margin:0 0 .75rem}.filename-template h4{font-size:.95rem}.filename-template__pattern{margin:.75rem 0;font-size:.9rem}.filename-template__segments{display:flex;flex-wrap:wrap;gap:.75rem;margin:1rem 0}.filename-template__segment{display:flex;flex-direction:column;gap:.35rem;min-width:120px}.filename-template__segment-value{display:inline-block;padding:.35rem .55rem;background:var(--surface);border:1px solid var(--border);border-radius:6px;font-family:ui-monospace,monospace;font-size:.85rem;max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.filename-template__segment select{padding:.45rem .5rem;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);color:var(--text);font-size:.85rem}.filename-template__files{margin-top:1rem}.filename-template__file-list{margin:.5rem 0 0;padding-left:0;list-style:none;max-height:180px;overflow-y:auto}.filename-template__file-list li{display:flex;align-items:center;gap:.5rem;padding:.25rem 0;font-size:.85rem;font-family:ui-monospace,monospace;word-break:break-all}.filename-template__ext{flex:0 0 auto;min-width:2.2rem;padding:.1rem .35rem;border-radius:4px;font-size:.7rem;font-weight:700;text-align:center}.filename-template__ext--jpg{background:#4f8cff2e;color:var(--primary)}.filename-template__ext--txt{background:#3dd68c26;color:var(--success)}.filename-template__preview ul{margin:.5rem 0 0;padding-left:0;list-style:none}.filename-template__preview li{display:flex;flex-wrap:wrap;gap:.5rem;padding:.3rem 0;font-size:.9rem}.filename-template__preview-name{font-weight:600}.filename-template--error{border-color:#ff6b6b59}.button-row{display:flex;gap:.75rem;flex-wrap:wrap}.bracket{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1.5rem;width:100%;align-items:start}.bracket-round{min-width:0}.bracket-round h3{margin:0 0 1rem;font-size:.95rem;color:var(--muted);text-transform:uppercase;letter-spacing:.05em}.knockout-view-toolbar{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap;margin-bottom:1rem}.knockout-view-legend{display:inline-flex;align-items:center;gap:.4rem;margin-left:auto;color:var(--muted);font-size:.85rem}.knockout-view-legend__swatch{width:.85rem;height:.85rem;border-radius:3px;border:1px solid rgba(61,214,140,.65);background:#3dd68c26;box-shadow:0 0 8px #3dd68c33}.third-place-bracket{margin-top:1.5rem;max-width:220px}.third-place-bracket .bracket-round{margin:0}.knockout-view-label{color:var(--muted);font-size:.9rem}.view-toggle{display:inline-flex;gap:.35rem;padding:.2rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius)}.view-toggle .btn.active{background:var(--primary);border-color:var(--primary);color:#fff}.bracket-grid-scroll{overflow-x:auto;padding-bottom:.75rem}.bracket-grid-wrap{margin-inline:auto}.bracket-grid-labels{display:grid;align-items:center;margin-bottom:.5rem}.bracket-grid-label{display:flex;align-items:center;height:1.25rem;font-size:.75rem;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;padding-inline:.25rem}.bracket-grid-label--left{justify-content:flex-end;padding-right:.4rem}.bracket-grid-label--center{justify-content:center}.bracket-grid-label--right{justify-content:flex-start;padding-left:.4rem}.bracket-grid-stage{position:relative}.bracket-grid-svg{position:absolute;top:0;left:0;pointer-events:none;z-index:0}.bracket-grid-svg line{stroke:#4a5d78;stroke-width:2}.bracket-grid-svg line.bracket-grid-line--winner-path{stroke:var(--success);stroke-width:2.5;filter:drop-shadow(0 0 4px rgba(61,214,140,.35))}.bracket-grid{position:relative;z-index:1;display:grid}.bracket-grid-cell{display:flex;align-items:center;justify-content:center;min-height:0}.bracket-grid-cell--left{justify-content:flex-end;padding-right:.15rem}.bracket-grid-cell--right{justify-content:flex-start;padding-left:.15rem}.bracket-grid-cell--center{justify-content:center}.match-card--compact{width:172px;height:calc(var(--bracket-grid-row-height, 38px) * 2);min-height:calc(var(--bracket-grid-row-height, 38px) * 2);max-height:calc(var(--bracket-grid-row-height, 38px) * 2);padding:.45rem .5rem;box-sizing:border-box;overflow:hidden;display:flex;flex-direction:column;justify-content:center}.match-card--compact .match-header{min-height:1.1rem;margin-bottom:.25rem;gap:.25rem;flex-wrap:nowrap}.match-card--compact .match-entrants{gap:.2rem}.match-card--compact .entrant-slot{padding:.28rem .45rem;font-size:.78rem;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.match-card--compact .status-badge{font-size:.62rem}.match-card--compact .btn-small{padding:.12rem .35rem;font-size:.68rem}.match-card--compact .match-winner{display:none}.round-matches{display:flex;flex-direction:column;gap:1rem}.match-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:.75rem}.match-card.highlight,.match-card.status-active{border-color:var(--primary);box-shadow:0 0 0 1px var(--primary)}.match-card--winner-path{border-color:#3dd68ca6;box-shadow:0 0 0 1px #3dd68c73,0 0 16px #3dd68c1f}.match-card--winner-path.match-card--compact{box-shadow:0 0 0 1px #3dd68c73,0 0 10px #3dd68c2e}.match-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem;flex-wrap:wrap}.status-badge{font-size:.7rem;padding:.15rem .45rem;border-radius:4px;text-transform:uppercase;font-weight:600}.status-badge.status-pending{background:var(--border);color:var(--muted)}.status-badge.status-active{background:var(--primary);color:#fff}.status-badge.status-completed{background:var(--success);color:#0f1419}.match-entrants{display:flex;flex-direction:column;gap:.35rem}.entrant-slot{display:block;width:100%;text-align:left;padding:.45rem .6rem;background:var(--bg);border:1px solid var(--border);border-radius:6px;color:var(--text);cursor:pointer;font-size:.9rem}.entrant-slot:hover{border-color:var(--primary)}.entrant-slot--winner{border-color:var(--success);box-shadow:0 0 0 1px color-mix(in srgb,var(--success) 35%,transparent)}.entrant-slot--winner:hover{border-color:var(--success)}.entrant-slot.empty{color:var(--muted);cursor:default}.vs-label{text-align:center;font-size:.75rem;color:var(--muted);font-weight:700}.match-winner{margin-top:.5rem;font-size:.8rem;color:var(--success)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;align-items:center;justify-content:center;padding:1rem;z-index:100}.modal{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.5rem;max-width:600px;width:100%;max-height:80vh;overflow-y:auto;position:relative}.modal-close{position:absolute;top:.5rem;right:.75rem;background:none;border:none;color:var(--muted);font-size:1.5rem;cursor:pointer}.modal h2{margin:0 0 1rem;padding-right:2rem}.modal--confirm p{margin:0 0 1rem}.modal--confirm__actions{justify-content:flex-end;margin-top:1.25rem}.prompt-label{font-size:.85rem;color:var(--muted);margin-bottom:.35rem}.prompt-text{white-space:pre-wrap;word-break:break-word;background:var(--bg);padding:1rem;border-radius:6px;font-size:.85rem;margin:0}.match-page .countdown{text-align:center;margin-bottom:2rem}.countdown-value{display:block;font-size:3rem;font-weight:700;color:var(--primary);line-height:1}.countdown-label{color:var(--muted);font-size:.9rem}.match-context{margin:.35rem 0 0;color:var(--muted);font-size:1rem}.vs-container{display:flex;align-items:flex-start;justify-content:center;gap:7.5rem;position:relative;max-width:960px;margin:0 auto}.vs-side{flex:1;min-width:240px;max-width:420px;background:var(--surface);border:2px solid var(--border);border-radius:var(--radius);padding:1rem;text-align:center;position:relative;z-index:1}.vs-side.winner{border-color:var(--success);box-shadow:0 0 24px #3dd68c26}.vs-side--zoomable,.vs-side__zoom-target{cursor:zoom-in}.vs-side__zoom-target:focus-visible{outline:2px solid var(--primary);outline-offset:2px;border-radius:6px}.vs-side__zoom-target h2{margin:.75rem 0 0}.vs-image-zoom-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;display:flex;align-items:center;justify-content:center;padding:1.5rem;background:#000000e0;cursor:zoom-out}.vs-image-zoom{max-width:min(95vw,1200px);max-height:92vh;width:auto;height:auto;object-fit:contain;border:5px solid var(--border);border-radius:var(--radius);box-shadow:0 12px 48px #00000073;pointer-events:none}.vs-image{width:100%;max-height:400px;object-fit:contain;border-radius:6px;background:var(--bg)}.vs-side h2{margin:.75rem 0;font-size:1.1rem}.vs-divider{position:absolute;left:50%;top:calc(1rem + min(190px,22vw));transform:translate(-50%,-50%);z-index:3;display:flex;align-items:center;justify-content:center;pointer-events:none;padding:0}.vs-logo{max-height:280px;max-width:min(250px,32vw);width:auto;height:auto;object-fit:contain;filter:drop-shadow(0 4px 20px rgba(0,0,0,.55));transform-origin:center center}@keyframes vs-heartbeat{0%,to{transform:scale(1)}14%{transform:scale(1.06)}28%{transform:scale(1)}42%{transform:scale(1.06)}56%{transform:scale(1)}}.vs-logo--pulse{animation:vs-heartbeat 1.35s ease-in-out infinite}@media(prefers-reduced-motion:reduce){.vs-logo--pulse{animation:none}}.btn-vote{width:100%;margin-top:.5rem}.voted-badge{color:var(--success);font-weight:600;margin:.5rem 0}.vote-count{color:var(--muted);font-size:.9rem}.abstained-badge{text-align:center;color:var(--warning);font-weight:600;margin:.5rem 0 1rem}.abstention-count{text-align:center;color:var(--muted);font-size:.9rem;margin:-.5rem 0 1rem}.abstain-section{max-width:520px;margin:1.5rem auto 0;text-align:center}.btn-abstain{width:100%}.abstain-hint{margin:.75rem 0 0;font-size:.85rem}.tie-notice{text-align:center;color:var(--warning);margin-bottom:1rem}.match-done{text-align:center;margin-top:2rem}.phase-label{margin:.25rem 0 0;color:var(--muted);font-size:.95rem}.section-title{margin:2rem 0 1rem;font-size:1.1rem}.format-hint{font-size:.9rem;color:var(--muted);margin:-.5rem 0 1rem}.format-hint.small{font-size:.85rem;margin-top:.5rem}.field select{padding:.6rem .75rem;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg);color:var(--text);font-size:1rem}.standings{margin-bottom:1.5rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1rem;width:100%}.standings h3{margin:0 0 .75rem;font-size:1rem}.standings-table{width:100%;border-collapse:collapse;font-size:.9rem}.standings-table th,.standings-table td{padding:.4rem .6rem;text-align:left;border-bottom:1px solid var(--border)}.standings-table th{color:var(--muted);font-weight:600}.standings-table tr.qualifies{background:#3dd68c14}.standings-table tr.qualifies td:last-child{color:var(--success);font-weight:600}.finalize-bar{display:flex;align-items:center;gap:1rem;flex-wrap:wrap;padding:1rem;background:#4f8cff1a;border:1px solid var(--primary);border-radius:var(--radius);margin-bottom:1.5rem}.finalize-bar p{margin:0}.auto-run-panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem 1.5rem;margin-bottom:1.5rem}.auto-run-panel h3{margin:0 0 .5rem;font-size:1.05rem}.field-inline{max-width:320px}.auto-run-status{margin:.75rem 0 0}.auto-run-countdown-banner{display:flex;align-items:center;justify-content:center;gap:.85rem;margin-bottom:1.25rem;padding:.85rem 1.25rem;background:#4f8cff1f;border:1px solid rgba(79,140,255,.35);border-radius:var(--radius);text-align:center;font-weight:600}.auto-run-countdown-banner__value{display:inline-flex;align-items:center;justify-content:center;min-width:2.5rem;min-height:2.5rem;padding:.35rem .55rem;border-radius:999px;background:var(--primary);color:#fff;font-size:1.15rem;font-weight:700;line-height:1}.auto-run-next-match{display:flex;align-items:center;justify-content:center;gap:.75rem;flex-wrap:wrap}.winner-display{position:relative;display:block;width:100%;margin:0}.winner-display__image-wrap{position:relative;padding-top:clamp(2.5rem,8vw,3.5rem)}.winner-badge{position:absolute;left:50%;top:0;z-index:2;max-height:min(110px,24vw);max-width:min(220px,72%);width:auto;height:auto;object-fit:contain;filter:drop-shadow(0 4px 20px rgba(0,0,0,.55));transform:translate(-50%);transform-origin:center center;pointer-events:none}.winner-badge--pulse{animation:winner-badge-pulse 1.35s ease-in-out infinite}@keyframes winner-badge-pulse{0%,to{transform:translate(-50%) scale(1)}14%{transform:translate(-50%) scale(1.06)}28%{transform:translate(-50%) scale(1)}42%{transform:translate(-50%) scale(1.06)}56%{transform:translate(-50%) scale(1)}}@media(prefers-reduced-motion:reduce){.winner-badge--pulse{animation:none}}.winner-display__photo{width:100%;max-height:400px;object-fit:contain;border-radius:6px;background:var(--bg);display:block}.winner-display--large .winner-display__photo{max-height:520px}.winner-display--large .winner-badge{max-height:min(150px,30vw);max-width:min(280px,80%)}.winner-display__name{margin:.75rem 0 0;font-size:1.1rem;font-weight:600}.tournament-champion,.tournament-podium{text-align:center;background:linear-gradient(180deg,rgba(61,214,140,.12),transparent);border:1px solid var(--border);border-radius:var(--radius);padding:2rem 1.5rem;margin-bottom:2rem}.tournament-podium__row{display:flex;align-items:flex-end;justify-content:center;gap:clamp(.75rem,3vw,2rem);flex-wrap:wrap}.tournament-podium__center{flex:0 1 auto;min-width:min(100%,320px)}.tournament-podium__side{flex:0 1 120px;min-width:100px;max-width:140px;opacity:.92}.tournament-podium__spacer{flex:0 1 120px;min-width:100px;max-width:140px}.tournament-podium__rank{margin:0 0 .5rem;font-size:.75rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--muted)}.tournament-podium__thumb{width:100%;aspect-ratio:1;object-fit:cover;border-radius:8px;border:1px solid var(--border);background:var(--bg)}.tournament-podium__name{margin:.5rem 0 0;font-size:.85rem;font-weight:600;line-height:1.3;word-break:break-word}.tournament-podium .tournament-champion__subtitle{margin-top:1.5rem;margin-bottom:0}.tournament-champion__eyebrow{margin:0 0 .35rem;color:var(--success);font-weight:700;letter-spacing:.08em;text-transform:uppercase;font-size:.85rem}.tournament-champion__title{margin:0 0 .5rem;font-size:clamp(1.5rem,4vw,2.2rem)}.tournament-champion__subtitle{margin:0 0 1.5rem}.match-page--final .match-done{text-align:center;margin-top:1.5rem}.entrant-gallery{margin-bottom:2rem}.entrant-gallery__header{display:flex;align-items:flex-end;justify-content:space-between;gap:1rem;flex-wrap:wrap;margin-bottom:.25rem}.entrant-gallery__header .section-title{margin-bottom:0}.entrant-gallery__sort{margin:0;min-width:200px}.entrant-gallery__hint{margin:.25rem 0 0}.entrant-gallery__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:1rem;margin-top:1.25rem}.entrant-gallery-card{display:flex;flex-direction:column;align-items:stretch;gap:.5rem;padding:.65rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;text-align:left;color:inherit;font:inherit;transition:border-color .15s,background .15s}.entrant-gallery-card:hover{background:var(--surface-hover);border-color:var(--primary)}.entrant-gallery-card--champion{border-color:var(--success);box-shadow:0 0 16px #3dd68c1f}.entrant-gallery-card__thumb{width:100%;aspect-ratio:1;object-fit:cover;border-radius:6px;background:var(--bg)}.entrant-gallery-card__name{font-size:.85rem;font-weight:600;line-height:1.3;word-break:break-word}.entrant-gallery-card__wins{font-size:.8rem;color:var(--muted)}.entrant-gallery-card__badge{align-self:flex-start;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--success)}.image-lightbox{position:relative;margin:0;max-width:min(920px,96vw);max-height:92vh;display:flex;flex-direction:column;align-items:center;gap:.75rem;padding:1rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius)}.image-lightbox__photo{max-width:100%;max-height:calc(92vh - 5rem);object-fit:contain;border-radius:6px;background:var(--bg)}.image-lightbox__name{margin:0;font-size:1.1rem;font-weight:600;text-align:center}.chat-panel{position:fixed;right:1rem;bottom:1rem;z-index:120;display:flex;flex-direction:column;align-items:flex-end;gap:.75rem;max-width:min(420px,calc(100vw - 2rem))}.chat-panel__toggle{box-shadow:0 8px 24px #00000059}.chat-panel__window{width:min(400px,calc(100vw - 2rem));height:min(520px,calc(100vh - 6rem));display:flex;flex-direction:column;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:0 12px 40px #00000073;overflow:hidden}.chat-panel__header{display:flex;align-items:center;justify-content:space-between;gap:.5rem;padding:.65rem .75rem;border-bottom:1px solid var(--border)}.chat-panel__tabs{display:flex;gap:.35rem}.chat-panel__tab{border:1px solid var(--border);background:var(--bg);color:var(--text);border-radius:999px;padding:.3rem .75rem;font:inherit;cursor:pointer}.chat-panel__tab.active{background:var(--primary);border-color:var(--primary);color:#fff}.chat-panel__close{background:none;border:none;color:var(--muted);font-size:1.4rem;cursor:pointer;line-height:1}.chat-panel__room-label{margin:0;padding:.35rem .75rem 0;font-size:.85rem}.chat-panel__anon{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;font-size:.85rem;border-bottom:1px solid var(--border)}.chat-panel__messages{flex:1;overflow-y:auto;padding:.75rem;display:flex;flex-direction:column;gap:.75rem}.chat-message{background:var(--bg);border:1px solid var(--border);border-radius:8px;padding:.55rem .65rem}.chat-message--own{border-color:#4f8cff73;background:#4f8cff14}.chat-message__meta{display:flex;justify-content:space-between;gap:.5rem;margin-bottom:.25rem;font-size:.8rem}.chat-message__meta span{color:var(--muted)}.chat-message p{margin:0;white-space:pre-wrap;word-break:break-word}.chat-panel__error{margin:0 .75rem;font-size:.85rem}.chat-panel__composer{display:flex;gap:.5rem;padding:.75rem;border-top:1px solid var(--border)}.chat-panel__composer input{flex:1;min-width:0;padding:.55rem .65rem;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg);color:var(--text);font:inherit}.round-recap-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:250;display:flex;align-items:center;justify-content:center;padding:1.5rem;background:#000000eb}.round-recap{width:min(920px,100%);text-align:center;padding:2rem 1.5rem;background:var(--surface);border:1px solid var(--border);border-radius:calc(var(--radius) * 1.2)}.round-recap__eyebrow{margin:0 0 .35rem;color:var(--primary);font-size:.8rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase}.round-recap h2{margin:0 0 1rem}.round-recap__progress{margin:0 0 1.25rem;color:var(--muted);font-size:.9rem}.round-recap__match{display:flex;align-items:center;justify-content:center;gap:1.25rem;margin-bottom:1rem}.round-recap__vs{color:var(--muted);font-weight:700;font-size:.85rem}.round-recap__side{flex:1;max-width:280px;padding:.75rem;background:var(--bg);border:2px solid var(--border);border-radius:var(--radius);transition:transform .45s ease,opacity .45s ease,border-color .45s ease,box-shadow .45s ease}.round-recap__side--winner{transform:scale(1.08);border-color:var(--success);box-shadow:0 0 28px #3dd68c40;z-index:1}.round-recap__side--loser{opacity:.45;transform:scale(.94)}.round-recap__side--empty{min-height:180px;display:flex;align-items:center;justify-content:center;color:var(--muted)}.round-recap__image{width:100%;max-height:220px;object-fit:contain;border-radius:6px;background:var(--surface)}.round-recap__name{margin:.65rem 0 0;font-weight:600;font-size:.95rem}.round-recap__tie{margin:0 0 1rem;color:var(--warning);font-size:.9rem}.round-recap__done{margin:0 0 1.25rem}.winner-path-cta{display:flex;justify-content:center;margin:-.5rem 0 1.5rem}.winner-path-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:260;display:flex;align-items:center;justify-content:center;padding:1.5rem;background:#000000eb;animation:winner-path-fade-in .35s ease}@keyframes winner-path-fade-in{0%{opacity:0}to{opacity:1}}.winner-path{width:min(920px,100%);text-align:center;padding:2rem 1.5rem;background:var(--surface);border:1px solid var(--border);border-radius:calc(var(--radius) * 1.2);animation:winner-path-slide-up .45s ease}@keyframes winner-path-slide-up{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}.winner-path__eyebrow{margin:0 0 .35rem;color:var(--success);font-size:.8rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase}.winner-path h2{margin:0 0 .5rem}.winner-path__round{margin:0 0 .35rem;color:var(--primary);font-weight:600}.winner-path__progress{margin:0 0 1.25rem;color:var(--muted);font-size:.9rem}.winner-path__match{display:flex;align-items:stretch;justify-content:center;gap:1.25rem;margin-bottom:1rem}.winner-path__vs{align-self:center;color:var(--muted);font-weight:700;font-size:.85rem}.winner-path__side{flex:1;max-width:280px;padding:.75rem;background:var(--bg);border:2px solid var(--border);border-radius:var(--radius);transition:transform .45s ease,opacity .45s ease,border-color .45s ease,box-shadow .45s ease}.winner-path__side--winner{transform:scale(1.08);border-color:var(--success);box-shadow:0 0 28px #3dd68c40;z-index:1}.winner-path__side--loser{opacity:.45;transform:scale(.94)}.winner-path__side--empty{min-height:180px;display:flex;align-items:center;justify-content:center;color:var(--muted)}.winner-path__image{width:100%;max-height:220px;object-fit:contain;border-radius:6px;background:var(--surface)}.winner-path__name{margin:.65rem 0 0;font-weight:600;font-size:.95rem}.winner-path__votes{margin:.35rem 0 0;color:var(--success);font-size:.9rem;font-weight:700;animation:winner-path-votes-pop .35s ease}@keyframes winner-path-votes-pop{0%{opacity:0;transform:scale(.85)}to{opacity:1;transform:scale(1)}}.winner-path__meta{margin-bottom:1rem}.winner-path__tie{margin:0;color:var(--warning);font-size:.9rem}.winner-path__abstain{margin:.35rem 0 0;font-size:.85rem}.winner-path__complete{margin-bottom:1.25rem}.winner-path__done{margin:0 0 1rem;font-size:1.05rem}.winner-path__timeline{display:flex;flex-wrap:wrap;justify-content:center;gap:.75rem 1.25rem;text-align:left}.winner-path__timeline-step{display:flex;align-items:center;gap:.45rem;padding:.45rem .75rem;background:var(--bg);border:1px solid var(--border);border-radius:999px;opacity:.55;transform:scale(.96);transition:opacity .35s ease,transform .35s ease,border-color .35s ease}.winner-path__timeline-step--done{opacity:1;transform:scale(1);border-color:#3dd68c73;animation:winner-path-step-in .4s ease}@keyframes winner-path-step-in{0%{opacity:0;transform:translateY(8px) scale(.92)}to{opacity:1;transform:translateY(0) scale(1)}}.winner-path__timeline-dot{width:.55rem;height:.55rem;border-radius:50%;background:var(--success);flex-shrink:0}.winner-path__timeline-label{font-size:.85rem;font-weight:600}.winner-path__timeline-score{font-size:.8rem}@media(max-width:700px){.vs-container{flex-direction:column;align-items:stretch;gap:1rem}.vs-divider{position:static;transform:none;order:2;padding:.25rem 0}.vs-logo{max-height:180px;max-width:min(200px,55vw)}}
