*{margin:0;padding:0;box-sizing:border-box}html{-webkit-tap-highlight-color:transparent;touch-action:manipulation}body{font-family:Outfit,Segoe UI,system-ui,-apple-system,sans-serif;background:#0d0d12;min-height:100vh;min-height:100dvh;display:flex;justify-content:center;align-items:center;color:#e8e8ed;overflow-x:hidden}#game-container{display:flex;flex-direction:column;align-items:center;gap:20px;padding:24px;max-width:900px}#game-header{text-align:center;width:100%}#game-header h1{font-size:2rem;font-weight:800;letter-spacing:-.02em;background:linear-gradient(135deg,#e74c3c,#3498db);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:4px}#tagline{font-size:.8rem;color:#6b6b7a;margin-bottom:16px;letter-spacing:.15em}#arena{display:flex;flex-direction:column;align-items:center;gap:8px}#player-panels{display:flex;align-items:center;gap:24px;padding:12px 24px;background:#ffffff0a;border-radius:12px;border:1px solid rgba(255,255,255,.08)}.player-panel{display:flex;align-items:center;gap:12px;padding:8px 16px;border-radius:10px;min-width:140px}.player-info{display:flex;flex-direction:column;gap:2px}.win-count{font-size:.75rem;color:#fff9}#p1-panel{background:linear-gradient(135deg,#e74c3c26,#c0392b14);border:1px solid rgba(231,76,60,.3)}#p2-panel{background:linear-gradient(135deg,#3498db26,#2980b914);border:1px solid rgba(52,152,219,.3)}.player-label{font-size:.85rem;font-weight:600}.piece-count{font-size:1.25rem;font-weight:800;min-width:1.5em}#p1-panel .piece-count{color:#e74c3c}#p2-panel .piece-count{color:#3498db}#vs{font-size:.75rem;font-weight:700;color:#4a4a55;letter-spacing:.2em}#status{font-size:.95rem;color:#a0a0ad}#play-area{display:flex;flex-direction:column;align-items:center;width:100%}main{display:flex;flex-direction:column;align-items:center;gap:12px;width:100%}.canvas-wrap{display:flex;align-items:center;justify-content:center;width:100%}#game-canvas{background:#15151c;border-radius:16px;box-shadow:0 0 0 1px #ffffff0f,0 16px 48px #00000080;cursor:crosshair;display:block;width:100%;max-width:800px;height:auto;aspect-ratio:800 / 450}#game-canvas.placing{cursor:pointer}.instructions{max-width:600px;padding:12px 20px;background:#ffffff08;border-radius:10px;font-size:.9rem;color:#7a7a8a;text-align:center}.help-btn{position:fixed;top:16px;right:16px;width:36px;height:36px;border-radius:50%;border:1px solid rgba(255,255,255,.2);background:#ffffff14;color:#ffffffb3;font-size:1.25rem;font-weight:700;cursor:pointer;z-index:1000;font-family:inherit;transition:background .2s,color .2s}.help-btn:hover{background:#ffffff26;color:#fff}.help-btn-mobile{position:static;width:28px;height:28px;font-size:.95rem;flex-shrink:0}.modal{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000bf;display:flex;align-items:center;justify-content:center;z-index:9999;padding:20px}.modal.hidden,.modal[hidden]{display:none}.modal-content{background:#1a1a22;border-radius:16px;padding:28px;max-width:480px;max-height:85vh;overflow-y:auto;border:1px solid rgba(255,255,255,.1);box-shadow:0 24px 48px #00000080}.modal-content h2{font-size:1.5rem;margin-bottom:16px;background:linear-gradient(135deg,#e74c3c,#3498db);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.rules-text{font-size:.95rem;line-height:1.6;color:#b0b0bd;margin-bottom:20px}.rules-text p{margin-bottom:12px}.rules-text ul{margin:12px 0;padding-left:20px}.rules-text li{margin-bottom:6px}.gameover-content{text-align:center;padding:40px 28px}.gameover-content h2{font-size:2rem;margin-bottom:24px}.gameover-buttons{display:flex;flex-direction:column;gap:10px}.modal-btn.secondary{background:#ffffff1a;border:1px solid rgba(255,255,255,.2)}.modal-btn{background:linear-gradient(135deg,#e74c3c,#3498db);color:#fff;border:none;padding:12px 28px;font-size:1rem;font-weight:600;border-radius:10px;cursor:pointer;font-family:inherit;touch-action:manipulation;-webkit-tap-highlight-color:transparent}.modal-btn:hover{opacity:.9;transform:scale(1.02)}.rotate-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0d0d12;z-index:8000;display:flex;align-items:center;justify-content:center;padding:24px}.rotate-overlay[hidden]{display:none!important}.rotate-content{text-align:center;max-width:280px}.rotate-icon{font-size:4rem;display:block;margin-bottom:20px;animation:rotate-hint 2s ease-in-out infinite}@keyframes rotate-hint{0%,to{transform:rotate(-15deg)}50%{transform:rotate(15deg)}}.rotate-content p{font-size:1.1rem;line-height:1.5;color:#a0a0ad}@media(max-width:600px),(max-height:500px){#game-container{padding:8px;gap:8px;width:100%;height:100vh;height:100dvh;max-height:100svh;justify-content:flex-start}#game-header{display:none}#play-area{display:flex;flex-direction:row;align-items:stretch;gap:8px;flex:1;min-height:0;width:100%}.help-btn-desktop{display:none}.mobile-sidebar{display:flex;flex-direction:column;align-items:center;justify-content:flex-start;gap:6px;flex-shrink:0;width:250px;min-width:250px;padding:8px 10px;background:#ffffff0a;border-radius:10px;border:1px solid rgba(255,255,255,.08)}.mobile-sidebar-header{display:flex;align-items:center;justify-content:space-between;width:100%;position:relative}.mobile-title{font-size:1rem;font-weight:800;background:linear-gradient(135deg,#e74c3c,#3498db);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:0;letter-spacing:-.02em}.mobile-tagline{font-size:.6rem;color:#6b6b7a;letter-spacing:.1em;margin:0}#mobile-arena{display:flex;flex-direction:column;align-items:center;gap:6px;width:100%}.mobile-vs{font-size:.6rem;font-weight:700;color:#4a4a55;letter-spacing:.15em}.player-panel-mobile{flex-direction:row;width:100%;min-width:0;padding:6px 10px;gap:8px;justify-content:space-between}.player-panel-mobile .piece-count{font-size:1.1rem}#game-container[data-current-turn=p1] #p1-panel-mobile{box-shadow:0 0 0 2px #e74c3ccc}#game-container[data-current-turn=p2] #p2-panel-mobile{box-shadow:0 0 0 2px #3498dbcc}main{flex:1;min-height:0;display:flex;flex-direction:column;gap:6px}.status-mobile{font-size:.7rem;color:#a0a0ad;text-align:center;line-height:1.2;margin-top:2px}.canvas-wrap{flex:1;min-height:0}#game-canvas{max-width:100%;max-height:100%;width:auto;height:auto}}@media(min-width:601px)and (min-height:501px){.mobile-sidebar,.status-mobile{display:none!important}}#game-container[data-current-turn=p1] #p1-panel{box-shadow:0 0 0 2px #e74c3ccc}#game-container[data-current-turn=p2] #p2-panel{box-shadow:0 0 0 2px #3498dbcc}@media(max-width:600px){#game-header h1{font-size:1.5rem}#tagline{font-size:.7rem;margin-bottom:10px;letter-spacing:.1em}#player-panels{gap:12px;padding:8px 16px}.player-panel{min-width:100px;padding:6px 12px;gap:8px}.player-label{font-size:.75rem}.piece-count{font-size:1.1rem}.win-count,#vs{font-size:.65rem}#status{font-size:.85rem}main{gap:8px;width:100%}.instructions{font-size:.8rem;padding:10px 16px;max-width:100%}.help-btn{top:12px;right:12px;width:32px;height:32px;font-size:1.1rem}.modal-content{padding:20px;max-height:90vh}.modal-content h2{font-size:1.25rem}.rules-text{font-size:.9rem;margin-bottom:16px}.modal-btn{padding:14px 24px;min-height:48px}}@media(max-height:450px)and (orientation:landscape){#game-container{padding:8px;gap:8px}#game-header h1{font-size:1.2rem}#tagline{display:none}#arena{gap:4px}#player-panels{padding:6px 12px;gap:8px}.player-panel{min-width:80px;padding:4px 8px}.player-label{font-size:.7rem}.piece-count{font-size:1rem}#status{font-size:.75rem}.instructions{font-size:.75rem;padding:6px 12px}}.lobby{position:fixed;top:0;right:0;bottom:0;left:0;background:#0d0d12;display:flex;align-items:center;justify-content:center;z-index:5000;padding:20px}.lobby.hidden{display:none}.lobby-content{text-align:center;padding:32px;max-width:420px;width:100%}.lobby-content h1{font-size:2.5rem;font-weight:800;background:linear-gradient(135deg,#e74c3c,#3498db);-webkit-background-clip:text;-webkit-text-fill-color:transparent;margin-bottom:8px}.lobby-sub{color:#6b6b7a;margin-bottom:32px}.lobby-buttons{display:flex;flex-direction:column;gap:12px}.lobby-btn{background:#ffffff14;border:1px solid rgba(255,255,255,.15);color:#e8e8ed;padding:16px 24px;font-size:1rem;font-weight:600;border-radius:12px;cursor:pointer;font-family:inherit;transition:background .2s,border-color .2s}.lobby-btn:hover{background:#ffffff1f;border-color:#ffffff40}.lobby-btn.primary{background:linear-gradient(135deg,#e74c3c4d,#3498db4d);border-color:#ffffff40;width:100%}.lobby-btn.primary:hover{opacity:.95}.lobby-view{text-align:left;position:relative}.lobby-back{position:absolute;top:0;left:0;background:transparent;border:none;color:#6b6b7a;font-size:.95rem;cursor:pointer;padding:4px 0;font-family:inherit;display:flex;align-items:center;gap:4px;transition:color .2s}.lobby-back:hover{color:#e8e8ed}.lobby-view-title{font-size:1.5rem;font-weight:700;margin-bottom:24px;padding-left:0;text-align:center;color:#e8e8ed}.pvp-tabs{display:flex;gap:8px;margin-bottom:24px;background:#ffffff0a;padding:4px;border-radius:12px}.pvp-tab{flex:1;padding:12px 16px;font-size:.95rem;font-weight:600;border:none;border-radius:8px;background:transparent;color:#6b6b7a;cursor:pointer;font-family:inherit;transition:background .2s,color .2s}.pvp-tab:hover{color:#a0a0ad}.pvp-tab.active{background:#ffffff1a;color:#e8e8ed}.pvp-panel-content{display:none}.pvp-panel-content.active{display:block}.pvp-hint{color:#6b6b7a;font-size:.9rem;margin-bottom:16px;line-height:1.4}.pvp-loading{display:flex;align-items:center;justify-content:center;gap:10px;padding:16px;color:#6b6b7a;font-size:.9rem}.pvp-spinner{width:20px;height:20px;border:2px solid rgba(255,255,255,.2);border-top-color:#3498db;border-radius:50%;animation:lobby-spin .8s linear infinite}@keyframes lobby-spin{to{transform:rotate(360deg)}}.pvp-error{color:#e74c3c;font-size:.9rem;margin-top:12px}.join-input-wrap{display:flex;gap:10px;margin-bottom:8px}.join-input-wrap input{flex:1;padding:14px 18px;font-size:1.25rem;letter-spacing:.25em;text-transform:uppercase;background:#ffffff0f;border:1px solid rgba(255,255,255,.15);border-radius:10px;color:#e8e8ed;font-family:SF Mono,Monaco,Consolas,monospace}.join-input-wrap input::placeholder{color:#4a4a55}.join-input-wrap input:focus{outline:none;border-color:#3498db;box-shadow:0 0 0 2px #3498db33}.room-created{margin-top:20px;padding:24px;background:#ffffff0a;border-radius:12px;border:1px solid rgba(255,255,255,.08)}.room-created-label{font-size:.9rem;color:#6b6b7a;margin-bottom:12px}.join-code-row{display:flex;align-items:center;gap:12px;margin-bottom:16px}.join-code{flex:1;font-size:2rem;font-weight:800;letter-spacing:.25em;color:#3498db;font-family:SF Mono,Monaco,Consolas,monospace;background:#3498db1a;padding:12px 16px;border-radius:8px}.lobby-btn.icon{padding:12px 16px;display:flex;align-items:center;gap:6px;flex-shrink:0}.copy-icon{font-size:1.1rem}.copy-feedback{font-size:.85rem}.waiting{color:#6b6b7a;font-size:.9rem}
