*,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}:before,:after{--tw-content: ""}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji";font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.absolute{position:absolute}.block{display:block}.flex{display:flex}.grid{display:grid}.border{border-width:1px}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.ease-in-out{transition-timing-function:cubic-bezier(.4,0,.2,1)}:root{--red:#e50914;--red-dark:#c0060f;--red-light:#fff0f0;--blue:#1565c0;--blue-light:#e8f0fb;--bg:#f5f5f5;--card:#fff;--card-dark:#1b1b2f;--text:#1a1a1a;--muted:#888;--border:#e8e8e8;--radius:12px}.ctrl-header{background:var(--red);padding:12px 20px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:100;box-shadow:0 2px 8px #e5091466}.back-link{font-size:13px;font-weight:700;color:#ffffffd9;text-decoration:none;cursor:pointer;background:none;border:none}.page-content{max-width:960px;margin:0 auto;padding:20px}@media (max-width:767px){.page-content{padding:0 0 24px}}@media (min-width:768px){.ctrl-layout{display:grid;grid-template-columns:1fr 1fr;gap:20px;align-items:start}}@media (max-width:767px){.ctrl-layout{display:flex;flex-direction:column;gap:0}}.score-card{background:var(--card-dark);color:#fff;padding:18px;border-radius:var(--radius);box-shadow:0 2px 10px #00000026}@media (max-width:767px){.score-card{border-radius:0}}.score-row{display:flex;align-items:center;justify-content:space-between}.team{display:flex;flex-direction:column;align-items:center;gap:4px;flex:1}.team-badge{width:38px;height:38px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:17px;border:2px solid rgba(255,255,255,.1)}.team-players{display:flex;flex-direction:column;align-items:center;gap:1px}.team-player{font-size:11px;color:#fff6;font-weight:600;min-height:14px}.score-center{display:flex;align-items:center;gap:10px;flex-shrink:0;padding:0 12px}.score-num{font-size:48px;font-weight:900;color:#fff;line-height:1;min-width:28px;text-align:center}.score-sep{font-size:24px;color:#fff3}.elo-row{display:flex;justify-content:space-around;flex-wrap:wrap;gap:8px;margin-top:14px;padding-top:12px;border-top:1px solid rgba(255,255,255,.08)}.elo-item{display:flex;flex-direction:column;align-items:center;gap:2px}.elo-label{font-size:10px;color:#ffffff4d;font-weight:700;text-transform:uppercase;letter-spacing:1px}.elo-delta{font-size:16px;font-weight:900}.elo-delta.pos{color:#a5d6a7}.elo-delta.neg{color:#ffcdd2}@media (max-width:767px){.controls-col{padding:14px 12px 0}}.btn-red{background:var(--red);border:none;border-radius:10px;padding:15px;font-size:14px;font-weight:800;color:#fff;cursor:pointer;font-family:sans-serif;transition:background .15s;width:100%}.btn-dark:disabled{opacity:.4;cursor:not-allowed}.btn-outline{background:var(--card);border:1.5px solid var(--border);border-radius:10px;padding:15px;font-size:14px;font-weight:800;color:var(--muted);cursor:pointer;font-family:sans-serif;width:100%;transition:background .15s}.btn-outline:hover:not(:disabled){background:var(--bg)}.btn-outline:disabled{opacity:.35;cursor:not-allowed}.preview-empty{background:var(--card-dark);border-radius:var(--radius);padding:36px 16px;display:flex;flex-direction:column;align-items:center;gap:10px}@media (max-width:767px){.preview-empty{border-radius:0}}.preview-empty .icon{font-size:38px;opacity:.2}.preview-empty .hint{font-size:13px;color:#ffffff40;font-weight:600;text-align:center;line-height:1.5}.preview-card{background:var(--card);border-radius:var(--radius);overflow:hidden;border:1px solid var(--border);box-shadow:0 1px 4px #0000000f;position:relative}@media (max-width:767px){.preview-card{border-radius:0;border-left:none;border-right:none}}.preview-card img{display:block;width:100%}.calibration-hint{position:absolute;left:10px;right:10px;bottom:10px;background:#e50914eb;color:#fff;border-radius:10px;padding:10px 12px;font-size:12px;font-weight:700;line-height:1.35;box-shadow:0 4px 14px #0003}:root{--red: #e50914;--red-dark: #c0060f;--bg: #f5f5f5;--card: #fff;--card-dark: #1b1b2f;--text: #1a1a1a;--muted: #888;--border: #e8e8e8;--radius: 12px}.logo{font-size:20px;font-weight:900;color:#fff}.back-link{font-size:13px;font-weight:700;color:#ffffffd9;text-decoration:none}.back-link:hover{color:#fff}.page-content{max-width:900px;margin:0 auto;padding:20px}@media (max-width: 767px){.page-content{padding:0 0 24px}}@media (min-width: 768px){.cam-layout{display:grid;grid-template-columns:340px 1fr;gap:20px;align-items:start}}@media (max-width: 767px){.cam-layout{display:flex;flex-direction:column}}.status-card{background:var(--card-dark);color:#fff;padding:14px 18px;border-radius:var(--radius);display:flex;justify-content:space-between;align-items:center;box-shadow:0 2px 8px #0000001f}@media (max-width: 767px){.status-card{border-radius:0}}.status-left .lbl{font-size:10px;font-weight:700;color:#ffffff59;text-transform:uppercase;letter-spacing:1px;margin-bottom:3px}.status-left .val{font-size:14px;font-weight:800;color:#fff}.status-pill{display:inline-flex;align-items:center;gap:5px;background:#ffffff1a;border-radius:6px;padding:6px 12px;font-size:11px;font-weight:700;color:#ffffff73}.status-pill.ok{background:#4caf504d;color:#a5d6a7}.status-pill.err{background:#e5091459;color:#ffcdd2}.status-dot{width:6px;height:6px;border-radius:50%;background:currentColor}.terrain-card{background:var(--card);border-radius:10px;padding:11px 16px;border:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;box-shadow:0 1px 3px #0000000d}@media (max-width: 767px){.terrain-card{border-radius:0;border-left:none;border-right:none}}.terrain-lbl{font-size:11px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:1px}.terrain-val{font-size:13px;font-weight:800;color:var(--muted)}.terrain-val.ok{color:#2e7d32}.controls-col{display:flex;flex-direction:column;gap:14px}@media (max-width: 767px){.controls-col{padding:14px 12px 0}}.section-title{font-size:11px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:1.5px;margin-bottom:8px}.btn-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}.btn-red:disabled{opacity:.35;cursor:not-allowed}.btn-dark{background:var(--card-dark);border:none;border-radius:10px;padding:15px;font-size:14px;font-weight:800;color:#fff;cursor:pointer;font-family:sans-serif;width:100%}.preview-empty{background:var(--card-dark);border-radius:var(--radius);padding:48px 16px;display:flex;flex-direction:column;align-items:center;gap:10px}@media (max-width: 767px){.preview-empty{border-radius:0}}.preview-empty .icon{font-size:42px;opacity:.18}.preview-empty .hint{font-size:13px;color:#ffffff38;font-weight:600;text-align:center;line-height:1.5}.preview-active{background:var(--card-dark);border-radius:var(--radius);overflow:hidden;position:relative}@media (max-width: 767px){.preview-active{border-radius:0}}.preview-active canvas{display:block;width:100%}.live-chip{position:absolute;top:10px;right:10px;background:var(--red);border-radius:5px;padding:3px 8px;font-size:10px;font-weight:800;color:#fff;letter-spacing:.5px;display:flex;align-items:center;gap:4px}.live-chip-dot{width:5px;height:5px;border-radius:50%;background:#fff;animation:blink 1.2s infinite}@keyframes blink{0%,to{opacity:1}50%{opacity:.2}}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--red: #e50914;--red-dark: #c0060f;--red-light: #fff0f0;--bg: #f5f5f5;--card: #ffffff;--card-dark: #1b1b2f;--text: #1a1a1a;--muted: #888;--border: #e8e8e8;--radius: 12px}body{font-family:sans-serif;background:var(--bg);color:var(--text);min-height:100vh}header{background:var(--red);padding:12px 20px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:100;box-shadow:0 2px 8px #e5091466}.logo{font-size:22px;font-weight:900;color:#fff;letter-spacing:-.5px}.live-badge{display:flex;align-items:center;gap:6px;background:#fff3;border:1px solid rgba(255,255,255,.3);border-radius:20px;padding:5px 14px;font-size:11px;font-weight:800;color:#fff;letter-spacing:.5px}.live-dot{width:7px;height:7px;border-radius:50%;background:#fff;animation:pulse 1.4s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.3}}nav{display:flex;gap:6px;background:var(--card);padding:10px 20px;border-bottom:1px solid var(--border);position:sticky;top:52px;z-index:90;overflow-x:auto;scrollbar-width:none}nav::-webkit-scrollbar{display:none}nav button{background:var(--bg);border:none;padding:7px 18px;font-size:13px;border-radius:20px;cursor:pointer;font-weight:700;color:var(--muted);white-space:nowrap;font-family:sans-serif;transition:all .15s;flex-shrink:0}nav button.active{background:var(--red);color:#fff}.section{display:none}.section.active{display:block}.page-content{max-width:1200px;margin:0 auto;padding:20px}@media (min-width: 768px){.live-layout{display:grid;grid-template-columns:1fr 380px;gap:20px;align-items:start}.live-left{display:flex;flex-direction:column;gap:14px}.live-right{display:flex;flex-direction:column;gap:14px;position:sticky;top:110px}.jouer-layout{display:grid;grid-template-columns:1fr 1fr;gap:16px}footer{display:none}body{padding-bottom:0}.desktop-sidebar{display:block;position:sticky;top:110px}}@media (max-width: 767px){body{padding-bottom:70px}.page-content{padding:0 0 12px}.live-layout{display:flex;flex-direction:column;gap:0}.live-left,.live-right,.jouer-layout{display:flex;flex-direction:column}.desktop-sidebar{display:none}}.match-card{background:var(--card-dark);color:#fff;padding:18px;border-radius:var(--radius);box-shadow:0 2px 10px #00000026}@media (max-width: 767px){.match-card{border-radius:0;margin:0;box-shadow:none}}.match-meta{display:flex;justify-content:space-between;font-size:11px;opacity:.45;margin-bottom:14px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.match-score{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.team{display:flex;flex-direction:column;align-items:center;gap:7px;flex:1}.team-badge{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:18px;border:2px solid rgba(255,255,255,.1)}.team-badge.red{background:#e509144d}.team-badge.blue{background:#1565c040}.team-name{font-size:13px;font-weight:700;color:#ffffffd9}.score-center{display:flex;align-items:center;gap:10px;flex-shrink:0;padding:0 16px}.score-num{font-size:52px;font-weight:900;color:#fff;line-height:1;min-width:32px;text-align:center}.score-sep{font-size:26px;color:#fff3}.dom-bar{height:4px;background:#ffffff14;border-radius:2px;overflow:hidden;margin-bottom:4px}.dom-fill{height:100%;background:var(--red);border-radius:2px;transition:width .5s}.dom-labels{display:flex;justify-content:space-between;font-size:11px;font-weight:700;opacity:.5}.status-tag{display:inline-block;background:#ffffff1a;border-radius:6px;padding:5px 10px;font-size:11px;font-weight:700;color:#ffffff80;margin-top:12px}.status-tag.ok{background:#4caf504d;color:#a5d6a7}.status-tag.err{background:#e5091459;color:#ffcdd2}.stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}@media (max-width: 767px){.stats-grid{margin:10px 12px 0}}.stat-card{background:var(--card);border-radius:10px;padding:14px 6px;text-align:center;border:1px solid var(--border);box-shadow:0 1px 4px #0000000d}.stat-val{font-size:18px;font-weight:800;color:var(--text)}.stat-val.red{color:var(--red)}.stat-lbl{font-size:9px;color:var(--muted);font-weight:700;text-transform:uppercase;letter-spacing:1px;margin-top:3px}.latency-card{background:var(--card);border-radius:10px;padding:12px 16px;border:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;box-shadow:0 1px 4px #0000000d}@media (max-width: 767px){.latency-card{margin:8px 12px 0}}.latency-card .lbl{font-size:11px;color:var(--muted);font-weight:700;text-transform:uppercase;letter-spacing:1px}.latency-card .val{font-size:14px;font-weight:800;color:var(--red)}.field-card{background:var(--card);border-radius:var(--radius);overflow:hidden;border:1px solid var(--border);position:relative;box-shadow:0 1px 4px #0000000f}@media (max-width: 767px){.field-card{border-radius:0;border-left:none;border-right:none}}canvas#terrain{display:block;width:100%;height:auto}.replay-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#000;display:none}@keyframes pausePulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.9)}}.replay-overlay .replay-label{position:absolute;top:12px;left:50%;transform:translate(-50%);background:var(--red);color:#fff;font-size:13px;font-weight:900;padding:4px 16px;border-radius:6px;letter-spacing:1px}.replay-overlay img{width:100%;height:100%;-o-object-fit:contain;object-fit:contain}.goal-flash{position:absolute;top:0;right:0;bottom:0;left:0;z-index:20;display:none;flex-direction:column;align-items:center;justify-content:center;pointer-events:none;border-radius:12px;animation:goalIn .25s cubic-bezier(.34,1.56,.64,1)}.goal-flash.red{background:#e5091473}.goal-flash.blue{background:#1565c073}@keyframes goalIn{0%{opacity:0;transform:scale(.7)}to{opacity:1;transform:scale(1)}}.goal-flash-title{font-size:58px;font-weight:900;color:#fff;text-shadow:0 2px 12px rgba(0,0,0,.6);letter-spacing:2px}.goal-flash-rod{margin-top:6px;font-size:18px;font-weight:800;color:#ffffffeb;background:#00000059;border-radius:8px;padding:5px 18px;text-transform:uppercase;letter-spacing:1px}.nav-card{background:var(--card);border-radius:var(--radius);padding:18px 16px;display:flex;align-items:center;justify-content:space-between;cursor:pointer;text-decoration:none;border:1px solid var(--border);box-shadow:0 1px 4px #0000000f;transition:box-shadow .15s,transform .1s}.nav-card:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-1px)}.nav-card:active{transform:translateY(0)}@media (max-width: 767px){.nav-card{border-radius:0;border-left:none;border-right:none;box-shadow:none}.nav-card:hover{transform:none;box-shadow:none}}.nav-card-left{display:flex;align-items:center;gap:16px}.nav-card-icon{width:48px;height:48px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:22px}.nav-card-icon.red-bg{background:var(--red-light)}.nav-card-icon.blue-bg{background:#e8f0fb}.nav-card-title{font-size:15px;font-weight:800;color:var(--text)}.nav-card-sub{font-size:12px;color:var(--muted);margin-top:2px;font-weight:600}.nav-card-arrow{font-size:22px;color:#ccc}.stats-empty{background:var(--card);border-radius:var(--radius);padding:48px 16px;display:flex;flex-direction:column;align-items:center;gap:10px;border:1px solid var(--border)}@media (max-width: 767px){.stats-empty{border-radius:0;border-left:none;border-right:none}}.stats-empty .icon{font-size:38px;opacity:.25}.stats-empty .hint{font-size:13px;color:var(--muted);font-weight:600;text-align:center}.leaderboard-row{background:var(--card);border-radius:10px;padding:12px 16px;border:1px solid var(--border);display:flex;align-items:center;gap:12px;box-shadow:0 1px 3px #0000000d}@media (max-width:767px){.leaderboard-row{border-radius:0;border-left:none;border-right:none}}.lb-rank{font-size:16px;font-weight:900;color:var(--muted);width:24px;text-align:center}.lb-rank.gold{color:#f9a825}.lb-rank.silver{color:#9e9e9e}.lb-rank.bronze{color:#8d6e63}.lb-name{flex:1}.lb-display{font-size:14px;font-weight:800;color:var(--text)}.lb-username{font-size:11px;color:var(--muted);font-weight:600}.lb-elo{font-size:18px;font-weight:900;color:var(--red)}.lb-stats{display:flex;flex-direction:column;align-items:flex-end;gap:2px}.lb-stat-line{font-size:11px;color:var(--muted);font-weight:600}.section-header{font-size:11px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:1.5px;margin-bottom:10px}@media (max-width: 767px){.section-header{padding:14px 12px 4px;margin:0}}.auth-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:999;background:#0000008c;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;padding:20px;animation:fadeIn .2s ease}.auth-overlay.hidden{display:none}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.auth-card{background:var(--card);border-radius:18px;width:100%;max-width:380px;box-shadow:0 24px 64px #00000038;overflow:hidden;animation:slideUp .25s cubic-bezier(.22,.68,0,1.2)}@keyframes slideUp{0%{transform:translateY(24px);opacity:0}to{transform:translateY(0);opacity:1}}.auth-header{background:var(--red);padding:22px 24px 18px}.auth-header .logo{font-size:18px;font-weight:900;color:#fff;letter-spacing:-.5px}.auth-header .subtitle{font-size:12px;color:#ffffffb3;font-weight:600;margin-top:2px}.auth-tabs{display:grid;grid-template-columns:1fr 1fr;border-bottom:1px solid var(--border)}.auth-tab{padding:13px;font-size:13px;font-weight:800;text-align:center;cursor:pointer;color:var(--muted);border:none;background:none;font-family:sans-serif;border-bottom:2px solid transparent;transition:all .15s}.auth-tab.active{color:var(--red);border-bottom-color:var(--red)}.auth-body{padding:20px 24px 24px;display:flex;flex-direction:column;gap:12px}.auth-field{display:flex;flex-direction:column;gap:5px}.auth-label{font-size:10px;font-weight:800;color:var(--muted);text-transform:uppercase;letter-spacing:1px}.auth-input{padding:11px 14px;border:1.5px solid var(--border);border-radius:9px;font-size:14px;font-family:sans-serif;color:var(--text);background:var(--bg);outline:none;transition:border-color .15s}.auth-input:focus{border-color:var(--red);background:#fff}.auth-error{font-size:12px;color:var(--red);font-weight:600;background:#fff0f0;border-radius:8px;padding:9px 12px;display:none}.auth-error.show{display:block}.auth-submit{background:var(--red);border:none;border-radius:10px;padding:14px;font-size:14px;font-weight:800;color:#fff;cursor:pointer;font-family:sans-serif;width:100%;transition:background .15s;margin-top:4px}.auth-submit:hover:not(:disabled){background:var(--red-dark)}.auth-submit:disabled{opacity:.5;cursor:not-allowed}.auth-user-bar{display:flex;align-items:center;justify-content:space-between;background:var(--card);border-radius:10px;padding:11px 14px;border:1px solid var(--border);margin-bottom:12px}.auth-user-bar .user-info{display:flex;flex-direction:column}.auth-user-bar .user-name{font-size:13px;font-weight:800;color:var(--text)}.auth-user-bar .user-elo{font-size:11px;color:var(--muted);font-weight:600}.auth-user-bar .btn-logout{font-size:12px;font-weight:700;color:var(--muted);background:var(--bg);border:1px solid var(--border);border-radius:7px;padding:6px 12px;cursor:pointer;font-family:sans-serif}.auth-user-bar .btn-logout:hover{color:var(--red);border-color:var(--red)}footer{display:flex;justify-content:space-around;padding:8px 0 12px;background:var(--card);border-top:1px solid var(--border);position:fixed;bottom:0;width:100%;z-index:100}footer button{background:none;border:none;font-size:11px;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:3px;padding:4px 16px;color:var(--muted);font-family:sans-serif;font-weight:700;position:relative}footer button.active{color:var(--red)}footer button.active:before{content:"";position:absolute;top:-8px;left:50%;transform:translate(-50%);width:28px;height:3px;background:var(--red);border-radius:0 0 3px 3px}footer button .icon{font-size:20px}.table-card{background:var(--card);border-radius:var(--radius);border:1.5px solid var(--border);padding:18px;cursor:pointer;transition:box-shadow .15s,transform .1s;box-shadow:0 1px 4px #0000000f;-webkit-user-select:none;-moz-user-select:none;user-select:none}.table-card:hover{box-shadow:0 4px 14px #0000001a;transform:translateY(-1px)}.table-card.occupied{cursor:default}.table-card.occupied:hover{transform:none;box-shadow:0 1px 4px #0000000f}@media (max-width:767px){.table-card{border-radius:0;border-left:none;border-right:none}}.table-card-top{display:flex;align-items:center;gap:14px}.table-icon{font-size:32px;flex-shrink:0}.table-title{font-size:16px;font-weight:900;color:var(--text)}.table-subtitle{font-size:12px;color:var(--muted);font-weight:600;margin-top:2px}.table-status-pill{margin-left:auto;flex-shrink:0;border-radius:20px;padding:5px 12px;font-size:11px;font-weight:800;letter-spacing:.3px}.table-status-pill.free{background:#e8f5e9;color:#2e7d32}.table-status-pill.matchmaking{background:#fff8e1;color:#f57f17}.table-status-pill.waiting_camera{background:#fff3e0;color:#e65100}.table-status-pill.calibrating{background:#e3f2fd;color:#1565c0}.table-status-pill.playing{background:#e509141a;color:var(--red)}.table-status-pill.paused{background:#f3e5f5;color:#6a1b9a}.table-score-row{display:flex;align-items:center;justify-content:center;gap:14px;margin-top:14px;padding-top:14px;border-top:1px solid var(--border)}.table-score-num{font-size:38px;font-weight:900;color:var(--text)}.table-score-sep{font-size:22px;color:var(--muted)}.mm-panel{background:var(--card);border-radius:var(--radius);border:1.5px solid var(--border);margin-top:12px;overflow:hidden;box-shadow:0 1px 4px #0000000f}@media (max-width:767px){.mm-panel{border-radius:0;border-left:none;border-right:none;margin-top:0;border-top:none}}.mm-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--border);font-size:13px;font-weight:800;color:var(--text)}.mm-leave{font-size:12px;font-weight:700;color:var(--muted);background:var(--bg);border:1px solid var(--border);border-radius:7px;padding:5px 11px;cursor:pointer;font-family:sans-serif}.mm-leave:hover{color:var(--red);border-color:var(--red)}.mm-players{display:flex;flex-direction:column}.mm-player-row{display:flex;align-items:center;gap:10px;padding:11px 16px;border-bottom:1px solid var(--border)}.mm-avatar{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:900;color:#fff;flex-shrink:0}.mm-player-name{font-size:13px;font-weight:800;flex:1}.mm-player-elo{font-size:11px;color:var(--muted);font-weight:700;margin-right:6px}.mm-ready-chip{font-size:10px;font-weight:800;padding:3px 8px;border-radius:5px;background:#e8f5e9;color:#2e7d32}.mm-waiting-chip{font-size:10px;font-weight:700;padding:3px 8px;border-radius:5px;background:var(--bg);color:var(--muted)}.mm-slot{padding:11px 16px;border-bottom:1px solid var(--border);font-size:12px;color:var(--muted);font-weight:600;font-style:italic}.mm-hint{padding:10px 16px;font-size:12px;color:var(--muted);font-weight:600;text-align:center;border-top:1px solid var(--border)}.mm-panel .btn-red{border-radius:0}.mode-choose{background:var(--card);border-radius:var(--radius);border:1.5px solid var(--border);padding:18px;margin-top:12px}@media (max-width:767px){.mode-choose{border-radius:0;border-left:none;border-right:none}}.role-panel{background:var(--card-dark);border-radius:var(--radius);padding:28px 24px;margin-top:12px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:8px}@media (max-width:767px){.role-panel{border-radius:0}}.role-panel-icon{font-size:44px}.role-panel-title{font-size:18px;font-weight:900;color:#fff}.role-panel-sub{font-size:13px;color:#ffffff80;font-weight:600;margin-bottom:8px}.role-panel .btn-red{max-width:200px;text-decoration:none;display:block;text-align:center}.section-title{font-size:11px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:1.5px}.mode-toggle{display:grid;grid-template-columns:1fr 1fr;border-radius:10px;overflow:hidden;border:1.5px solid var(--border)}.mode-btn{background:var(--card);border:none;padding:13px;font-size:14px;font-weight:800;color:var(--muted);cursor:pointer;font-family:sans-serif;transition:all .15s}.mode-btn:first-child{border-right:1px solid var(--border)}.mode-btn.active{background:var(--card-dark);color:#fff}.btn-red{background:var(--red);border:none;border-radius:10px;padding:15px;font-size:14px;font-weight:800;color:#fff;cursor:pointer;font-family:sans-serif;width:100%;transition:background .15s}.btn-red:hover:not(:disabled){background:var(--red-dark)}.btn-outline{background:var(--card);border:1.5px solid var(--border);border-radius:10px;padding:15px;font-size:14px;font-weight:800;color:var(--muted);cursor:pointer;font-family:sans-serif;width:100%}.header-avatar{width:34px;height:34px;border-radius:50%;background:#ffffff38;border:2px solid rgba(255,255,255,.4);color:#fff;font-size:14px;font-weight:900;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s,transform .1s;font-family:sans-serif;flex-shrink:0}.header-avatar:hover{background:#ffffff59;transform:scale(1.08)}.profile-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;background:#0006;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);animation:fadeIn .18s ease;display:none}.profile-overlay.open{display:block}.profile-drawer{position:fixed;top:0;right:0;bottom:0;z-index:201;width:min(360px,92vw);background:var(--card);box-shadow:-8px 0 32px #0000002e;display:flex;flex-direction:column;transform:translate(100%);transition:transform .28s cubic-bezier(.22,.68,0,1.1)}.profile-drawer.open{transform:translate(0)}.profile-drawer-header{background:var(--red);padding:20px 18px 18px;display:flex;align-items:center;gap:14px}.profile-drawer-avatar{width:52px;height:52px;border-radius:50%;background:#ffffff40;border:2px solid rgba(255,255,255,.5);display:flex;align-items:center;justify-content:center;font-size:22px;font-weight:900;color:#fff;flex-shrink:0}.profile-drawer-name{font-size:16px;font-weight:900;color:#fff}.profile-drawer-user{font-size:12px;color:#ffffffb3;font-weight:600;margin-top:1px}.profile-drawer-close{margin-left:auto;background:#ffffff2e;border:none;color:#fff;font-size:18px;width:32px;height:32px;border-radius:50%;cursor:pointer;font-family:sans-serif;display:flex;align-items:center;justify-content:center;flex-shrink:0}.profile-drawer-close:hover{background:#ffffff52}.profile-drawer-body{flex:1;overflow-y:auto;padding:18px;display:flex;flex-direction:column;gap:14px}.profile-elo-banner{background:var(--card-dark);border-radius:12px;padding:16px;display:flex;align-items:center;gap:14px}.profile-elo-val{font-size:38px;font-weight:900;color:var(--red);line-height:1}.profile-elo-label{font-size:10px;font-weight:700;color:#ffffff59;text-transform:uppercase;letter-spacing:1px}.profile-elo-sub{font-size:12px;color:#ffffff8c;font-weight:600;margin-top:2px}.profile-stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.profile-stat-card{background:var(--bg);border-radius:10px;padding:12px 6px;text-align:center;border:1px solid var(--border)}.profile-stat-val{font-size:20px;font-weight:900;color:var(--text)}.profile-stat-val.red{color:var(--red)}.profile-stat-lbl{font-size:9px;color:var(--muted);font-weight:700;text-transform:uppercase;letter-spacing:1px;margin-top:3px}.profile-section-title{font-size:10px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:1.5px;margin-bottom:6px}.profile-history{display:flex;flex-direction:column;gap:7px}.profile-match-row{background:var(--bg);border-radius:10px;padding:11px 14px;border:1px solid var(--border);display:flex;align-items:center;gap:10px}.profile-match-result{width:28px;height:28px;border-radius:7px;font-size:11px;font-weight:900;display:flex;align-items:center;justify-content:center;flex-shrink:0}.profile-match-result.win{background:#e8f5e9;color:#2e7d32}.profile-match-result.loss{background:#ffebee;color:var(--red)}.profile-match-result.draw{background:#f5f5f5;color:var(--muted)}.profile-match-score{font-size:13px;font-weight:800;color:var(--text);flex:1}.profile-match-meta{font-size:10px;color:var(--muted);font-weight:600}.profile-match-elo{font-size:12px;font-weight:800}.profile-match-elo.pos{color:#2e7d32}.profile-match-elo.neg{color:var(--red)}.profile-match-elo.neu{color:var(--muted)}.profile-empty{text-align:center;padding:28px 16px;font-size:13px;color:var(--muted);font-weight:600}.profile-drawer-footer{padding:14px 18px;border-top:1px solid var(--border)}.profile-drawer-footer .btn-logout-full{width:100%;background:var(--bg);border:1.5px solid var(--border);border-radius:10px;padding:13px;font-size:13px;font-weight:800;color:var(--muted);cursor:pointer;font-family:sans-serif;transition:all .15s}.profile-drawer-footer .btn-logout-full:hover{color:var(--red);border-color:var(--red);background:#fff0f0}
