.board-container{display:flex;flex-direction:column;align-items:center;gap:4px;width:100%}.board-label{font-size:12px;font-weight:600;color:var(--matrix-green);margin-bottom:4px;text-transform:uppercase;letter-spacing:2px;font-family:Fira Code,monospace;width:100%;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:16px;min-height:16px}.board-label:before{content:"[ ";color:var(--matrix-green-dim)}.board-label:after{content:" ]";color:var(--matrix-green-dim)}.board-wrapper{display:flex;flex-direction:column;gap:0;width:100%}.board-coords-row{display:flex;gap:2px;padding-left:0;padding-right:4px;width:100%}.board-coord-corner{width:calc(clamp(12px,4vw,16px) + 6px);height:clamp(12px,3vw,16px);flex-shrink:0}.board-coord-col{flex:1;height:clamp(12px,3vw,16px);display:flex;align-items:center;justify-content:center;font-size:clamp(8px,2.5vw,10px);font-family:Fira Code,monospace;color:var(--matrix-green-dim);text-shadow:0 0 5px var(--matrix-green-glow)}.board-main{display:grid;grid-template-columns:auto 1fr;gap:0;width:100%}.board-coords-col{display:grid;grid-template-rows:repeat(10,1fr);gap:2px;padding-right:2px;padding-top:4px;padding-bottom:4px}.board-coord-row{width:clamp(12px,4vw,16px);display:flex;align-items:center;justify-content:center;font-size:clamp(8px,2.5vw,10px);font-family:Fira Code,monospace;color:var(--matrix-green-dim);text-shadow:0 0 5px var(--matrix-green-glow)}.board{display:grid;grid-template-columns:repeat(10,1fr);grid-template-rows:repeat(10,1fr);gap:2px;background:var(--matrix-border);padding:2px;border:2px solid var(--matrix-green-dim);box-shadow:0 0 15px var(--matrix-green-glow),inset 0 0 10px #00ff000d;touch-action:none;min-width:0;width:100%;aspect-ratio:1}.board--placement{touch-action:none;-webkit-touch-callout:none;border-color:var(--matrix-green)}.cell{width:100%;height:100%;background:var(--matrix-bg);border:1px solid var(--matrix-border);cursor:pointer;transition:all .15s ease;display:grid;place-items:center;font-size:clamp(6px,3vw,14px);font-family:Fira Code,monospace;outline:none;-webkit-tap-highlight-color:transparent;color:var(--matrix-green);padding:0;min-width:0;min-height:0;position:relative;line-height:1;overflow:hidden}.cell--hit:after,.cell--miss:after,.cell--sunk:after,.cell--auto-miss:after,.cell--pending:after,.cell--preview:after{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;pointer-events:none}@media (hover: none){.cell:hover:not(.cell--disabled):not(.cell--hit):not(.cell--miss):not(.cell--sunk):not(.cell--ship):not(.cell--auto-miss){background:var(--matrix-bg);opacity:1}}.cell:hover:not(.cell--disabled):not(.cell--hit):not(.cell--miss):not(.cell--sunk):not(.cell--ship):not(.cell--auto-miss){background:var(--matrix-bg-secondary);border-color:var(--matrix-green);box-shadow:inset 0 0 10px var(--matrix-green-glow)}.cell:active:not(.cell--disabled):not(.cell--hit):not(.cell--miss):not(.cell--sunk):not(.cell--auto-miss){background:var(--matrix-green-dark);transform:scale(.95)}.cell--ship{background:var(--matrix-green);border-color:var(--matrix-green-bright);box-shadow:0 0 8px var(--matrix-green-glow);transition:all .2s ease}.cell--ship:after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:50%;height:3px;background:#0006;border-radius:1px;pointer-events:none}.cell--ship.cell--ship-v:after{width:3px;height:50%}.cell--ship:not(.cell--ship-h):not(.cell--ship-v):after{width:30%;height:30%;border-radius:50%}.board--placement .cell--ship{cursor:grab;touch-action:none}.board--placement .cell--ship:hover{transform:scale(1.05);box-shadow:0 0 15px var(--matrix-green)}.board--placement .cell--ship:active{cursor:grabbing;transform:scale(.95)}.cell--hit{background:var(--matrix-red);border-color:var(--matrix-red);box-shadow:0 0 10px var(--matrix-red-glow);animation:hit-explosion .5s ease-out}.cell--hit:after{content:"✗";font-size:1.15em;color:#fff;text-shadow:0 0 5px #ffffff;animation:hit-symbol .3s ease-out}@keyframes hit-explosion{0%{transform:scale(1.5);background:#fff;box-shadow:0 0 30px var(--matrix-red),0 0 50px #ffffff80}30%{background:var(--matrix-red);transform:scale(1.2)}to{transform:scale(1);box-shadow:0 0 10px var(--matrix-red-glow)}}@keyframes hit-symbol{0%{opacity:0;transform:scale(2)}50%{opacity:1}to{transform:scale(1)}}.cell--miss{background:var(--matrix-grid);animation:miss-ripple .4s ease-out}.cell--miss:after{content:"•";font-size:1.15em;color:var(--matrix-green-dim);opacity:.6;animation:miss-fade .4s ease-out}@keyframes miss-ripple{0%{box-shadow:0 0 0 0 var(--matrix-green-glow)}50%{box-shadow:0 0 10px 5px var(--matrix-green-glow)}to{box-shadow:none}}@keyframes miss-fade{0%{opacity:0;transform:scale(0)}to{opacity:.6;transform:scale(1)}}.cell--sunk{background:linear-gradient(135deg,#401,#602,#401);border-color:#ff4060;box-shadow:0 0 8px var(--matrix-red-glow),inset 0 0 4px #ff00404d;animation:sunk-destruction .6s ease-out,sunk-glow-pulse 2s ease-in-out .6s infinite}.cell--sunk:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border:2px solid #ff4060;pointer-events:none}.cell--sunk:after{content:"☠";font-size:1em;color:#ff4060;text-shadow:0 0 6px var(--matrix-red);animation:sunk-symbol .4s ease-out .2s both}@keyframes sunk-destruction{0%{background:var(--matrix-red);box-shadow:0 0 30px var(--matrix-red),0 0 50px var(--matrix-red-glow);transform:scale(1.1)}30%{background:#a02}to{background:linear-gradient(135deg,#401,#602,#401);box-shadow:0 0 8px var(--matrix-red-glow),inset 0 0 4px #ff00404d;transform:scale(1)}}@keyframes sunk-glow-pulse{0%,to{box-shadow:0 0 8px var(--matrix-red-glow),inset 0 0 4px #ff00404d}50%{box-shadow:0 0 16px var(--matrix-red),0 0 24px var(--matrix-red-glow),inset 0 0 8px #ff004066}}@keyframes sunk-symbol{0%{opacity:0}to{opacity:1}}.cell--sunk.cell--ship-h:before{border-left-width:0;border-right-width:0}.cell--sunk.cell--ship-h.cell--ship-start:before{border-left-width:2px}.cell--sunk.cell--ship-h.cell--ship-end:before{border-right-width:2px}.cell--sunk.cell--ship-h.cell--ship-start.cell--ship-end:before{border-left-width:2px;border-right-width:2px}.cell--sunk.cell--ship-v:before{border-top-width:0;border-bottom-width:0}.cell--sunk.cell--ship-v.cell--ship-start:before{border-top-width:2px}.cell--sunk.cell--ship-v.cell--ship-end:before{border-bottom-width:2px}.cell--sunk.cell--ship-v.cell--ship-start.cell--ship-end:before{border-top-width:2px;border-bottom-width:2px}.cell--auto-miss{background:var(--matrix-grid);animation:auto-miss-appear .4s ease-out;cursor:not-allowed}.cell--auto-miss:after{content:"·";font-size:1em;color:var(--matrix-green-dim);opacity:.35;animation:auto-miss-dot .4s ease-out .15s both}@keyframes auto-miss-appear{0%{background:transparent}to{background:var(--matrix-grid)}}@keyframes auto-miss-dot{0%{opacity:0;transform:scale(0)}to{opacity:.35;transform:scale(1)}}.cell--pending{background:var(--matrix-green-dark);border-color:var(--matrix-green);animation:scan-pending .6s ease-in-out infinite}.cell--pending:after{content:"◎";font-size:1em;color:var(--matrix-green)}@keyframes scan-pending{0%,to{box-shadow:0 0 5px var(--matrix-green-glow)}50%{box-shadow:0 0 15px var(--matrix-green),0 0 25px var(--matrix-green-glow)}}.cell--preview{background:var(--matrix-green-dark);border-color:var(--matrix-green);opacity:.8;animation:preview-pulse .5s ease-in-out infinite}.cell--preview:after{content:"░";font-size:1.15em;color:var(--matrix-green)}@keyframes preview-pulse{0%,to{opacity:.6}50%{opacity:.9}}.cell--invalid{background:#ff00404d;border-color:var(--matrix-red);animation:invalid-shake .3s ease-in-out}@keyframes invalid-shake{0%,to{transform:translate(0)}25%{transform:translate(-2px)}75%{transform:translate(2px)}}.cell--disabled{cursor:not-allowed;opacity:.4}.board--placement .cell:hover:not(.cell--ship):not(.cell--disabled):not(.cell--preview):not(.cell--invalid){background:var(--matrix-bg);border-color:var(--matrix-border);box-shadow:none}.ship-pool{display:flex;flex-direction:column;gap:6px;padding:8px;background:var(--matrix-bg-secondary);border:1px solid var(--matrix-border);min-width:80px;flex-shrink:1;min-height:0;overflow:hidden}.ship-pool-title{font-size:10px;font-weight:600;text-align:center;color:var(--matrix-green);font-family:Fira Code,monospace;letter-spacing:2px;text-shadow:0 0 5px var(--matrix-green-glow)}.ship-pool-title:before{content:"[ ";color:var(--matrix-green-dim)}.ship-pool-title:after{content:" ]";color:var(--matrix-green-dim)}.ship-pool-list{display:flex;flex-direction:column;gap:6px;min-height:0;overflow:auto;overscroll-behavior:contain;-webkit-overflow-scrolling:touch;padding-right:2px}.ship-pool-row{display:flex;flex-direction:column;gap:3px}.ship-pool-meta{display:flex;align-items:center;gap:4px;font-family:Fira Code,monospace}.ship-pool-size{font-size:10px;color:var(--matrix-green);font-weight:600}.ship-pool-count{font-size:9px;color:var(--matrix-green-dim);font-family:Fira Code,monospace}.ship-pool-ships{display:flex;flex-direction:column;gap:3px}.pool-ship{padding:3px 4px;border:1px solid var(--matrix-border);background:var(--matrix-bg);cursor:grab;transition:all .2s ease;touch-action:none;user-select:none;-webkit-user-select:none;display:flex;align-items:center;width:fit-content}.pool-ship:hover{border-color:var(--matrix-green);box-shadow:0 0 10px var(--matrix-green-glow)}.pool-ship:active{cursor:grabbing;transform:scale(.98)}.ship-pool--dragging .pool-ship{cursor:grabbing}.pool-ship-cells{display:flex;gap:2px}.pool-ship-cell{width:14px;height:14px;background:var(--matrix-green);border:1px solid var(--matrix-green-bright);box-shadow:0 0 3px var(--matrix-green-glow);flex-shrink:0}.ship-pool-hint{font-size:8px;color:var(--matrix-green-dark);text-align:center;font-family:Fira Code,monospace;letter-spacing:1px}@media (max-width: 400px){.ship-pool{min-width:65px;padding:6px;gap:4px}.pool-ship-cell{width:11px;height:11px}.pool-ship{padding:2px 3px}.pool-ship-cells{gap:1px}}@media (max-width: 450px){.ship-pool-list{flex-direction:row;flex-wrap:wrap;gap:8px;justify-content:center}.ship-pool-row{align-items:center}.ship-pool-ships{flex-direction:row;gap:4px}}.drag-ghost{pointer-events:none;z-index:1000}.drag-ghost-ship{opacity:.9;transform:scale(1.05);filter:drop-shadow(0 0 15px var(--matrix-green-glow))}.drag-ghost-ship--invalid{opacity:.7;filter:drop-shadow(0 0 15px var(--matrix-red-glow))}.drag-ghost-cell{background:var(--matrix-green);border:1px solid var(--matrix-green-bright);transition:all .15s ease;box-shadow:0 0 10px var(--matrix-green-glow)}.drag-ghost-ship--invalid .drag-ghost-cell{background:var(--matrix-red);border-color:var(--matrix-red);box-shadow:0 0 10px var(--matrix-red-glow)}.help-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000e6;display:flex;align-items:center;justify-content:center;z-index:10000;padding:16px;animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.help-modal{background:var(--matrix-bg);border:2px solid var(--matrix-green);box-shadow:0 0 30px var(--matrix-green-glow),inset 0 0 20px #00ff000d;max-width:400px;width:100%;max-height:80vh;overflow-y:auto;animation:slideIn .3s ease-out}@keyframes slideIn{0%{transform:translateY(-20px);opacity:0}to{transform:translateY(0);opacity:1}}.help-header{display:flex;justify-content:space-between;align-items:center;padding:16px;border-bottom:1px solid var(--matrix-border)}.help-title{font-family:Fira Code,monospace;font-size:16px;color:var(--matrix-green);letter-spacing:2px;text-shadow:0 0 10px var(--matrix-green-glow);margin:0}.help-close{background:none;border:none;color:var(--matrix-green);font-size:20px;cursor:pointer;padding:4px 8px;transition:all .2s}.help-close:hover{color:var(--matrix-red);text-shadow:0 0 10px var(--matrix-red-glow)}.help-content{padding:16px}.help-section{margin-bottom:20px}.help-section:last-child{margin-bottom:0}.help-section-title{font-family:Fira Code,monospace;font-size:12px;color:var(--matrix-green-dim);letter-spacing:2px;margin:0 0 12px;padding-bottom:4px;border-bottom:1px solid var(--matrix-border)}.help-section-title:before{content:"> ";color:var(--matrix-green)}.help-list{list-style:none;padding:0;margin:0}.help-list li{font-family:Fira Code,monospace;font-size:12px;color:var(--matrix-green);padding:6px 0 6px 16px;position:relative}.help-list li:before{content:"•";position:absolute;left:0;color:var(--matrix-green-dim)}.help-key{background:var(--matrix-bg-secondary);border:1px solid var(--matrix-border);padding:2px 6px;font-size:10px;color:var(--matrix-cyan);margin-right:8px}.help-ships{display:flex;flex-direction:column;gap:8px}.help-ship-row{display:flex;align-items:center;gap:12px;font-family:Fira Code,monospace;font-size:12px}.help-ship-visual{color:var(--matrix-green);min-width:60px}.help-ship-info{color:var(--matrix-green-dim)}.help-legend{display:flex;flex-direction:column;gap:8px}.help-legend-item{display:flex;align-items:center;gap:12px;font-family:Fira Code,monospace;font-size:12px;color:var(--matrix-green)}.help-cell{width:24px;height:24px;display:flex;align-items:center;justify-content:center;border:1px solid var(--matrix-border)}.help-cell--ship{background:var(--matrix-green);color:var(--matrix-bg)}.help-cell--hit{background:var(--matrix-red);color:#fff}.help-cell--miss{background:var(--matrix-grid);color:var(--matrix-green-dim)}.help-modal .btn{margin:16px;width:calc(100% - 32px)}.fleet-status{display:flex;align-items:center;gap:5px;font-family:Fira Code,monospace;font-size:10px;margin-top:2px}.fleet-status-label{color:var(--matrix-green-dim);font-size:8px;letter-spacing:1px;min-width:32px}.fleet-status-ships{display:flex;gap:6px;align-items:center;flex-wrap:wrap}.fleet-row{display:flex;align-items:center;gap:2px}.fleet-row--sunk{opacity:.4}.fleet-row--sunk .fleet-count{color:var(--matrix-red);text-decoration:line-through}.fleet-blocks{display:flex;gap:1px}.fleet-block{width:7px;height:7px;background:var(--matrix-green);border:1px solid var(--matrix-green-bright);box-shadow:0 0 2px var(--matrix-green-glow)}.fleet-block--sunk{background:var(--matrix-red);border-color:var(--matrix-red);box-shadow:0 0 2px var(--matrix-red-glow)}.fleet-count{color:var(--matrix-green-dim);font-size:8px;min-width:18px}@media (max-height: 620px){.fleet-status-label{display:none}.fleet-block{width:5px;height:5px}.fleet-status{margin-top:1px;gap:3px}.fleet-status-ships{gap:4px}.fleet-count{font-size:7px;min-width:14px}}.menu-screen{background:var(--matrix-bg);position:relative}.menu-header{position:absolute;top:16px;right:16px;display:flex;gap:8px}.help-button{width:36px;height:36px;border:2px solid var(--matrix-green);background:var(--matrix-bg);color:var(--matrix-green);font-family:Fira Code,monospace;font-size:18px;font-weight:700;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.help-button:hover{background:var(--matrix-green);color:var(--matrix-bg);box-shadow:0 0 15px var(--matrix-green-glow)}.help-button:active{transform:scale(.95)}.menu-ascii-art{text-align:center;margin-top:20px}.menu-ascii-art pre{font-family:Fira Code,monospace;font-size:11px;color:var(--matrix-green);text-shadow:0 0 10px var(--matrix-green-glow);line-height:1.2;margin:0;animation:matrix-glow 2s ease-in-out infinite}.menu-terminal{padding:12px;background:var(--matrix-bg-secondary);border:1px solid var(--matrix-border);margin-top:16px}.terminal-line{display:flex;align-items:center;gap:8px;font-family:Fira Code,monospace;font-size:12px}.terminal-prompt{color:var(--matrix-green)}.terminal-text{color:var(--matrix-green-dim)}.menu-screen .difficulty-buttons{margin-top:24px}.menu-screen .difficulty-buttons .screen-subtitle{margin-bottom:12px;color:var(--matrix-green-dim)}.queue-screen{background:var(--matrix-bg)}.queue-terminal{padding:16px;background:var(--matrix-bg-secondary);border:1px solid var(--matrix-border);font-family:Fira Code,monospace;font-size:13px}.queue-line{display:flex;gap:12px;margin-bottom:8px}.queue-line:last-child{margin-bottom:0}.queue-label{color:var(--matrix-green-dim);min-width:100px}.queue-value{color:var(--matrix-green)}.queue-value--active{animation:matrix-glow 1s ease-in-out infinite}.queue-progress{color:var(--matrix-green);font-size:11px}.queue-spinner-container{display:flex;flex-direction:column;align-items:center;gap:24px;margin:32px 0}.queue-spinner{position:relative;width:80px;height:80px;display:flex;align-items:center;justify-content:center}.spinner-ring{position:absolute;width:100%;height:100%;border:2px solid var(--matrix-border);border-top-color:var(--matrix-green);animation:spin 1s linear infinite}.spinner-ring--delayed{width:60%;height:60%;animation-delay:-.5s;animation-direction:reverse}@keyframes spin{to{transform:rotate(360deg)}}.spinner-text{font-size:24px;color:var(--matrix-green);animation:pulse-glow 1s ease-in-out infinite}@keyframes pulse-glow{0%,to{text-shadow:0 0 5px var(--matrix-green-glow);opacity:.7}50%{text-shadow:0 0 15px var(--matrix-green),0 0 25px var(--matrix-green-glow);opacity:1}}.queue-status{font-family:Fira Code,monospace;font-size:14px;color:var(--matrix-green-dim);letter-spacing:2px}.placement-screen{padding:10px 12px;padding-bottom:calc(10px + env(safe-area-inset-bottom,0px));background:var(--matrix-bg);touch-action:none;-webkit-user-select:none;user-select:none;gap:6px}.placement-back-btn{align-self:flex-start;font-size:11px;padding:6px 12px;border-color:var(--matrix-green-dark);color:var(--matrix-green-dim);flex-shrink:0}.placement-screen .screen-title{font-size:16px;letter-spacing:3px;flex-shrink:0}.placement-screen .screen-subtitle{font-size:11px;flex-shrink:0}.placement-content{display:flex;gap:8px;justify-content:center;align-items:stretch;touch-action:none;margin-top:2px;flex:1;min-height:0}.placement-board{flex-shrink:0;touch-action:none;width:min(70vw,300px,calc(100dvh - 220px))}.placement-content .ship-pool{max-height:var(--board-px, 280px)}.placement-actions{display:flex;gap:8px;justify-content:center;margin-top:6px;flex-shrink:0;padding-bottom:env(safe-area-inset-bottom,0px)}.placement-actions .btn{font-size:11px;padding:8px 12px}@media (max-width: 450px){.placement-content{flex-direction:column;align-items:center}.placement-content .ship-pool{max-height:min(var(--board-px, 280px),30dvh);width:min(92vw,420px)}.placement-board{width:min(78vw,calc(100dvh - 290px))}.placement-actions{flex-wrap:wrap}}@media (max-height: 600px){.placement-screen{padding:6px 10px;padding-bottom:calc(6px + env(safe-area-inset-bottom,0px));gap:4px}.placement-board{width:min(58vw,calc(100dvh - 220px))}.placement-actions{margin-top:4px}}.placement-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000d9;display:flex;align-items:center;justify-content:center;z-index:100}.placement-overlay-content{display:flex;flex-direction:column;align-items:center;gap:16px}.placement-overlay-text{font-family:Fira Code,monospace;font-size:14px;letter-spacing:2px;color:var(--matrix-green-dim);animation:pulse-warning 1.5s ease-in-out infinite}.placement-overlay-text--ready{color:var(--matrix-green);text-shadow:0 0 10px var(--matrix-green-glow);animation:none}.battle-screen{background:var(--matrix-bg);padding:8px 10px;padding-bottom:calc(8px + env(safe-area-inset-bottom,0px));min-height:0;gap:4px}.opponent-disconnected-banner{background:#ffaa0026;border:1px solid #ffaa00;color:#fa0;font-family:Fira Code,monospace;font-size:10px;letter-spacing:1px;padding:4px 10px;text-align:center;flex-shrink:0;animation:pulse-disconnect 1.5s ease-in-out infinite}@keyframes pulse-disconnect{0%,to{opacity:1}50%{opacity:.6}}.battle-screen .turn-indicator{font-family:Fira Code,monospace;font-size:12px;letter-spacing:2px;flex-shrink:0;padding:6px 10px;white-space:nowrap;min-height:30px;line-height:1}.battle-screen .time-warning{color:var(--matrix-red);animation:pulse-warning .5s ease-in-out infinite}.battle-screen .time-normal{color:var(--matrix-green-dim);opacity:.85}@keyframes pulse-warning{0%,to{opacity:1}50%{opacity:.5}}.battle-screen .boards-container{gap:2px;flex:1;min-height:0;overflow:hidden;justify-content:flex-start}.battle-screen .board-section{display:flex;flex-direction:column;align-items:center;flex:0 0 auto}.battle-screen .board-section .board-container{width:min(88vw,calc((100dvh - 300px)/2),40dvh,320px)}.battle-surrender-btn{flex-shrink:0;margin-top:auto;padding:5px 12px!important;font-size:11px!important}@media (max-height: 700px){.battle-screen .turn-indicator{font-size:11px;padding:5px 8px}.battle-surrender-btn{padding:4px 10px!important;font-size:10px!important}}@media (max-height: 550px){.battle-screen{padding:4px 8px;padding-bottom:calc(4px + env(safe-area-inset-bottom,0px));gap:2px}.battle-screen .board-section .board-container{width:min(85vw,calc((100dvh - 240px)/2),36dvh,260px)}}.result-screen{background:var(--matrix-bg)}.result-ascii{text-align:center}.result-ascii pre{font-family:Fira Code,monospace;font-size:10px;line-height:1.1;margin:0}.result-screen--win .result-ascii pre{color:var(--matrix-green);text-shadow:0 0 10px var(--matrix-green-glow);animation:matrix-glow 1.5s ease-in-out infinite}.result-screen--lose .result-ascii pre{color:var(--matrix-red);text-shadow:0 0 10px var(--matrix-red-glow)}.result-title{font-family:Fira Code,monospace;font-size:20px;text-align:center;letter-spacing:3px;margin-top:16px}.result-title--win{color:var(--matrix-green);text-shadow:0 0 15px var(--matrix-green-glow);animation:matrix-glow 1s ease-in-out infinite}.result-title--lose{color:var(--matrix-red);text-shadow:0 0 10px var(--matrix-red-glow)}.result-details{margin-top:24px;padding:16px;background:var(--matrix-bg-secondary);border:1px solid var(--matrix-border);font-family:Fira Code,monospace;font-size:12px}.result-line{display:flex;gap:12px;margin-bottom:8px}.result-line:last-child{margin-bottom:0}.result-label{color:var(--matrix-green-dim);min-width:80px}.result-value{color:var(--matrix-green)}.result-screen--lose .result-value{color:var(--matrix-red)}.profile-screen{background:var(--matrix-bg);padding:12px 16px;padding-bottom:calc(12px + env(safe-area-inset-bottom,0px));gap:12px;overflow-y:auto}.profile-header{display:flex;align-items:center;gap:12px;flex-shrink:0}.profile-back-btn{padding:4px 10px!important;font-size:11px!important;flex-shrink:0}.profile-title{font-family:Fira Code,monospace;font-size:16px;letter-spacing:3px;color:var(--matrix-green);text-shadow:0 0 10px var(--matrix-green-glow)}.profile-stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;flex-shrink:0}.profile-stat{background:var(--matrix-bg-secondary);border:1px solid var(--matrix-border);padding:10px 6px;text-align:center}.profile-stat-value{font-family:Fira Code,monospace;font-size:20px;font-weight:700;color:var(--matrix-green);text-shadow:0 0 8px var(--matrix-green-glow)}.profile-stat--win .profile-stat-value{color:var(--matrix-green)}.profile-stat--loss .profile-stat-value{color:var(--matrix-red)}.profile-stat-label{font-family:Fira Code,monospace;font-size:9px;letter-spacing:1px;color:var(--matrix-green-dim);margin-top:4px}.profile-accuracy-section{background:var(--matrix-bg-secondary);border:1px solid var(--matrix-border);padding:10px 12px;flex-shrink:0}.profile-accuracy-header{display:flex;justify-content:space-between;font-family:Fira Code,monospace;font-size:12px;letter-spacing:2px;color:var(--matrix-green-dim);margin-bottom:8px}.profile-accuracy-value{color:var(--matrix-green);font-weight:700;text-shadow:0 0 5px var(--matrix-green-glow)}.profile-accuracy-bar-bg{height:8px;background:var(--matrix-border);overflow:hidden}.profile-accuracy-bar{height:100%;background:var(--matrix-green);box-shadow:0 0 6px var(--matrix-green-glow);transition:width .5s ease}.profile-accuracy-details{display:flex;justify-content:space-between;font-family:Fira Code,monospace;font-size:10px;color:var(--matrix-green-dim);margin-top:6px;opacity:.7}.profile-streak{font-family:Fira Code,monospace;font-size:12px;letter-spacing:2px;text-align:center;padding:6px 12px;flex-shrink:0}.profile-streak--win{color:var(--matrix-green);border:1px solid var(--matrix-green);background:#00ff000d}.profile-streak--loss{color:var(--matrix-red);border:1px solid var(--matrix-red);background:#ff00400d}.profile-history-section{flex:1;min-height:0;display:flex;flex-direction:column}.profile-history-title{font-family:Fira Code,monospace;font-size:12px;letter-spacing:2px;color:var(--matrix-green-dim);margin-bottom:8px;flex-shrink:0}.profile-history-empty{font-family:Fira Code,monospace;font-size:11px;color:var(--matrix-green-dim);opacity:.5;text-align:center;padding:20px}.profile-history-list{display:flex;flex-direction:column;gap:4px;overflow-y:auto;flex:1;min-height:0}.profile-match{display:flex;align-items:center;gap:10px;padding:6px 10px;background:var(--matrix-bg-secondary);border-left:3px solid transparent;font-family:Fira Code,monospace}.profile-match--win{border-left-color:var(--matrix-green)}.profile-match--loss{border-left-color:var(--matrix-red)}.profile-match-result{font-size:14px;font-weight:700;width:20px;text-align:center}.profile-match--win .profile-match-result{color:var(--matrix-green)}.profile-match--loss .profile-match-result{color:var(--matrix-red)}.profile-match-info{flex:1;min-width:0}.profile-match-opponent{font-size:12px;color:var(--matrix-green);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.profile-match-details{font-size:9px;color:var(--matrix-green-dim);opacity:.7;letter-spacing:.5px}.profile-match-date{font-size:9px;color:var(--matrix-green-dim);opacity:.5;white-space:nowrap}*{box-sizing:border-box;margin:0;padding:0}:root{--matrix-bg: #000000;--matrix-bg-secondary: #001100;--matrix-green: #00ff00;--matrix-green-bright: #00ff41;--matrix-green-dim: #00aa00;--matrix-green-dark: #006600;--matrix-green-glow: rgba(0, 255, 0, .4);--matrix-red: #ff0040;--matrix-red-glow: rgba(255, 0, 64, .4);--matrix-cyan: #00ffff;--matrix-grid: #002200;--matrix-border: #003300;--tg-theme-bg-color: var(--matrix-bg);--tg-theme-text-color: var(--matrix-green);--tg-theme-hint-color: var(--matrix-green-dark);--tg-theme-link-color: var(--matrix-cyan);--tg-theme-button-color: var(--matrix-green);--tg-theme-button-text-color: var(--matrix-bg);--tg-theme-secondary-bg-color: var(--matrix-bg-secondary)}html{overscroll-behavior:none;overscroll-behavior-y:none;-webkit-touch-callout:none}html,body{overscroll-behavior:none;overscroll-behavior-y:none}body{font-family:Fira Code,Consolas,Monaco,monospace;background:var(--matrix-bg);color:var(--matrix-green);height:100vh;height:100dvh;position:fixed;width:100%;overflow:hidden;background-image:repeating-linear-gradient(0deg,transparent,transparent 2px,rgba(0,255,0,.03) 2px,rgba(0,255,0,.03) 4px)}#root{height:100vh;height:100dvh;display:flex;flex-direction:column;overflow-y:auto;overflow-x:hidden;overscroll-behavior:contain}@keyframes matrix-glow{0%,to{text-shadow:0 0 5px var(--matrix-green),0 0 10px var(--matrix-green-glow)}50%{text-shadow:0 0 10px var(--matrix-green),0 0 20px var(--matrix-green),0 0 30px var(--matrix-green-glow)}}@keyframes matrix-flicker{0%,to{opacity:1}92%{opacity:1}93%{opacity:.8}94%{opacity:1}97%{opacity:.9}}@keyframes cursor-blink{0%,50%{opacity:1}51%,to{opacity:0}}@keyframes typewriter{0%{width:0}to{width:100%}}@keyframes glitch{0%{transform:translate(0);text-shadow:0 0 10px var(--matrix-green-glow)}2%{transform:translate(2px);text-shadow:-2px 0 var(--matrix-red),2px 0 var(--matrix-cyan)}4%{transform:translate(-2px);text-shadow:2px 0 var(--matrix-red),-2px 0 var(--matrix-cyan)}6%{transform:translate(0);text-shadow:0 0 10px var(--matrix-green-glow)}to{transform:translate(0);text-shadow:0 0 10px var(--matrix-green-glow)}}.glitch{animation:glitch 3s ease-in-out infinite}.screen:after{content:"";position:fixed;top:0;left:0;right:0;bottom:0;background:repeating-linear-gradient(0deg,transparent,transparent 2px,rgba(0,255,0,.03) 2px,rgba(0,255,0,.03) 4px);pointer-events:none;z-index:9999}.terminal-text{font-family:Fira Code,monospace;color:var(--matrix-green);text-shadow:0 0 5px var(--matrix-green-glow)}.neon-glow{text-shadow:0 0 5px var(--matrix-green),0 0 10px var(--matrix-green),0 0 20px var(--matrix-green),0 0 40px var(--matrix-green-glow)}@keyframes screen-flicker{0%,to{opacity:1}92%{opacity:1}93%{opacity:.95}94%{opacity:1}97%{opacity:.98}}.screen{animation:screen-flicker 8s ease-in-out infinite}.screen{flex:1;min-height:0;display:flex;flex-direction:column;padding:16px;padding-bottom:calc(16px + env(safe-area-inset-bottom,0px));padding-top:calc(16px + env(safe-area-inset-top,0px));gap:12px}.screen-title{font-size:20px;font-weight:700;text-align:center;text-transform:uppercase;letter-spacing:2px;color:var(--matrix-green);text-shadow:0 0 10px var(--matrix-green-glow);animation:matrix-glow 2s ease-in-out infinite}.screen-subtitle{font-size:14px;color:var(--matrix-green-dim);text-align:center;font-family:Fira Code,monospace}.screen-subtitle:before{content:"> ";color:var(--matrix-green)}.btn{display:flex;align-items:center;justify-content:center;padding:12px 20px;border:2px solid var(--matrix-green);border-radius:0;font-size:14px;font-weight:600;font-family:Fira Code,monospace;cursor:pointer;text-transform:uppercase;letter-spacing:1px;transition:all .2s ease;position:relative;overflow:hidden}.btn:before{content:"[ ";color:var(--matrix-green-dim)}.btn:after{content:" ]";color:var(--matrix-green-dim)}.btn:active{transform:scale(.98)}.btn:disabled{opacity:.4;cursor:not-allowed;border-color:var(--matrix-green-dark)}.btn--primary{background:var(--matrix-green);color:var(--matrix-bg);box-shadow:0 0 10px var(--matrix-green-glow),inset 0 0 10px #0000004d}.btn--primary:hover:not(:disabled){box-shadow:0 0 20px var(--matrix-green),0 0 30px var(--matrix-green-glow)}.btn--secondary{background:transparent;color:var(--matrix-green);border-color:var(--matrix-green-dim)}.btn--secondary:hover:not(:disabled){background:var(--matrix-bg-secondary);border-color:var(--matrix-green);box-shadow:0 0 15px var(--matrix-green-glow)}.btn--danger{background:transparent;color:var(--matrix-red);border-color:var(--matrix-red)}.btn--danger:before,.btn--danger:after{color:var(--matrix-red)}.btn--danger:hover:not(:disabled){background:#ff00401a;box-shadow:0 0 15px var(--matrix-red-glow)}.btn--full{width:100%}.spacer{flex:1}.difficulty-buttons{display:flex;flex-direction:column;gap:12px}.turn-indicator{text-align:center;padding:12px 16px;border:2px solid var(--matrix-border);font-weight:600;font-family:Fira Code,monospace;text-transform:uppercase;letter-spacing:1px}.turn-indicator--your-turn{background:var(--matrix-bg-secondary);color:var(--matrix-green);border-color:var(--matrix-green);box-shadow:0 0 15px var(--matrix-green-glow);animation:matrix-pulse 1.5s ease-in-out infinite}.turn-indicator--your-turn:before{content:">>> "}.turn-indicator--your-turn:after{content:" <<<"}.turn-indicator--opponent-turn{background:var(--matrix-bg);color:var(--matrix-green-dark);border-color:var(--matrix-border)}.turn-indicator--opponent-turn:before{content:"... "}@keyframes matrix-pulse{0%,to{box-shadow:0 0 10px var(--matrix-green-glow)}50%{box-shadow:0 0 20px var(--matrix-green),0 0 30px var(--matrix-green-glow)}}.boards-container{display:flex;flex-direction:column;gap:6px;align-items:center}.result-icon{font-size:48px;text-align:center;text-shadow:0 0 20px var(--matrix-green-glow)}.loading{display:flex;flex-direction:column;align-items:center;gap:16px}.spinner{width:50px;height:50px;border:3px solid var(--matrix-border);border-top-color:var(--matrix-green);border-radius:0;animation:matrix-spin 1s steps(8) infinite;box-shadow:0 0 15px var(--matrix-green-glow)}@keyframes matrix-spin{to{transform:rotate(360deg)}}.cursor{display:inline-block;width:10px;height:18px;background:var(--matrix-green);animation:cursor-blink 1s steps(1) infinite;vertical-align:middle;margin-left:2px}
