*,*:before,*:after{box-sizing:border-box}body{margin:0;font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;-webkit-font-smoothing:antialiased}.app{display:flex;flex-direction:column;align-items:center;min-height:100vh;padding:1.5rem 1rem 3rem;background:#1a1610;color:#e8d8b0;font-family:system-ui,sans-serif}.app-title{font-size:2rem;letter-spacing:.08em;color:#d4a843;margin:0 0 .25rem}.nostr-badge{font-size:1rem;color:#a78bfa;font-weight:400;letter-spacing:0}.error-banner{display:flex;align-items:flex-start;gap:.75rem;background:#3a1010;border:1px solid #cc4444;color:#f88;border-radius:6px;padding:.6rem .9rem;max-width:500px;margin-bottom:1rem;font-size:.9rem;white-space:pre-line}.timeout-banner{display:flex;align-items:center;gap:.75rem;background:#2e2010;border:1px solid #c87020;color:#f0a040;border-radius:6px;padding:.6rem .9rem;max-width:600px;margin-bottom:.75rem;font-size:.9rem}.error-close{background:none;border:none;color:#f88;cursor:pointer;flex-shrink:0;line-height:1;padding:0;font-size:.95rem}.screen{display:flex;flex-direction:column;align-items:center;width:100%;max-width:460px;margin-top:1rem}.screen.center{justify-content:center;margin-top:4rem;gap:1.2rem;color:#a89060}.screen-subtitle{color:#a89060;margin:0 0 2rem;font-size:1rem}.connect-screen{margin-top:3rem}.resume-info{background:#2e2820;border:1px solid #5a4830;border-radius:6px;padding:.75rem 1rem;margin-bottom:1.25rem;width:100%;display:flex;flex-direction:column;gap:.4rem}.resume-row{display:flex;align-items:center;gap:.75rem}.resume-label{font-size:.8rem;color:#a89060;width:5rem;flex-shrink:0}.connect-buttons{display:flex;flex-direction:column;gap:1rem;width:100%}.anon-section{display:flex;flex-direction:column;gap:.6rem;width:100%}.anon-label{text-align:center;font-size:.8rem;color:#7a6040;margin:0}.anon-name-row{display:flex;gap:.4rem;align-items:center}.about-section{margin-top:2.5rem;padding-top:1.5rem;border-top:1px solid #3a3020;width:100%;display:flex;flex-direction:column;gap:.75rem}.about-title{font-size:.7rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:#7a6040;margin:0}.about-title+.about-title{margin-top:.5rem}.about-text{font-size:.85rem;color:#a89060;line-height:1.6;margin:0}.about-link{color:#d4a843;text-decoration:none}.about-link:hover{text-decoration:underline}.about-meta{font-size:.78rem;color:#6a5030}.about-features{margin:0;padding-left:1.1rem;display:flex;flex-direction:column;gap:.3rem;font-size:.85rem;color:#a89060;line-height:1.5}.spinner{width:36px;height:36px;border:3px solid #3a3020;border-top-color:#d4a843;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.btn{display:flex;flex-direction:column;align-items:center;padding:.7rem 1.4rem;border:none;border-radius:6px;cursor:pointer;font-size:1rem;font-weight:600;transition:opacity .15s}.btn:hover{opacity:.85}.btn-primary{background:#d4a843;color:#1a1610}.btn-secondary{background:#2e2820;color:#e8d8b0;border:1px solid #5a4830}.btn-small{padding:.3rem .8rem;font-size:.85rem;flex-direction:row}.btn-ghost{background:transparent;color:#a89060;border:1px solid #3a3020}.btn-danger{background:#7a1a1a;color:#f88;border:1px solid #cc4444}.btn-sub{font-size:.75rem;font-weight:400;opacity:.7;margin-top:.15rem}.identity-line{display:flex;flex-direction:column;align-items:center;gap:.4rem;margin:0 0 1.2rem;width:100%}.identity-label{font-size:.8rem;color:#a89060}.npub-full{font-size:.72rem;word-break:break-all;text-align:center;line-height:1.5}.lobby-nav{display:flex;gap:.5rem;width:100%;margin-bottom:1.25rem}.lobby-nav-btn{flex:1;background:#2e2820;border:1px solid #5a4830;border-radius:8px;color:#a89060;padding:.7rem .4rem .55rem;cursor:pointer;font-size:.82rem;font-weight:600;display:flex;flex-direction:column;align-items:center;gap:.3rem;transition:border-color .15s,color .15s}.lobby-nav-btn:hover{border-color:#8a6840;color:#c8a870}.lobby-nav-btn.active{border-color:#d4a843;color:#d4a843}.lobby-nav-btn.empty{opacity:.45}.lobby-nav-badge{background:#d4a843;color:#1a1610;border-radius:10px;font-size:.68rem;font-weight:700;padding:.05rem .45rem;min-width:1.2rem;text-align:center;line-height:1.4}.lobby-empty{display:flex;flex-direction:column;align-items:center;gap:1.25rem;padding:2.5rem 0;color:#a89060;font-size:.9rem;width:100%}.seek-section{display:flex;flex-direction:column;gap:.5rem;width:100%;margin-bottom:1.25rem}.seeking-status{display:flex;align-items:center;gap:.75rem;background:#2e2820;border:1px solid #5a4830;border-radius:6px;padding:.65rem .9rem;font-size:.9rem;color:#d4a843}.seek-hint{margin:0;font-size:.78rem;color:#9a8060}.tabs{display:flex;gap:.25rem;margin-bottom:1.25rem;border-bottom:1px solid #3a3020;width:100%}.tab{background:none;border:none;color:#a89060;padding:.5rem 1.2rem;cursor:pointer;font-size:.95rem;border-bottom:2px solid transparent;margin-bottom:-1px;transition:color .15s}.tab.active{color:#d4a843;border-bottom-color:#d4a843}.lobby-form{display:flex;flex-direction:column;gap:.75rem;width:100%}.form-label{font-size:.85rem;color:#a89060}.form-input{background:#2e2820;border:1px solid #5a4830;border-radius:5px;color:#e8d8b0;font-size:.95rem;padding:.55rem .75rem;outline:none;font-family:monospace;width:100%;box-sizing:border-box}.form-input:focus{border-color:#d4a843}.join-code-box{background:#2e2820;border:1px solid #5a4830;border-radius:6px;padding:.9rem;display:flex;flex-direction:column;gap:.5rem;margin-top:.5rem}.join-code-label{font-size:.82rem;color:#a89060;margin:0}.join-code{font-size:.78rem;color:#e8d8b0;word-break:break-all;font-family:monospace}.game-list{width:100%;margin-bottom:1.25rem}.game-list-title{font-size:.8rem;color:#a89060;margin:0 0 .5rem;text-transform:uppercase;letter-spacing:.06em}.game-list-item{display:flex;align-items:center;justify-content:space-between;background:#2e2820;border:1px solid #5a4830;border-radius:6px;padding:.6rem .8rem;margin-bottom:.5rem;gap:.75rem}.game-list-info{display:flex;flex-direction:column;gap:.2rem;min-width:0}.game-list-status{font-size:.85rem;font-weight:600;color:#a89060}.game-list-status.your-turn{color:#d4a843}.game-list-status.won{color:#6b8eff}.game-list-status.lost{color:#a89060}.game-list-actions{display:flex;gap:.4rem;flex-shrink:0}.player-search{position:relative;width:100%}.search-input-row{display:flex;align-items:center;gap:.4rem}.search-input-row .form-input{flex:1}.search-spinner{width:14px;height:14px;border:2px solid #3a3020;border-top-color:#d4a843;border-radius:50%;animation:spin .8s linear infinite;flex-shrink:0}.search-dropdown{position:absolute;top:calc(100% + 4px);left:0;right:0;background:#242010;border:1px solid #5a4830;border-radius:6px;z-index:100;overflow-y:auto;max-height:240px;box-shadow:0 6px 20px #00000080}.search-result{display:flex;align-items:center;gap:.6rem;width:100%;padding:.55rem .75rem;background:none;border:none;border-bottom:1px solid #3a3020;cursor:pointer;text-align:left;color:#e8d8b0}.search-result:last-child{border-bottom:none}.search-result:hover{background:#2e2820}.search-result-info{display:flex;flex-direction:column;gap:.1rem;min-width:0}.search-result-name{font-size:.9rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.search-result-nip05{font-size:.72rem;color:#a89060;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.search-selected{display:flex;align-items:center;gap:.5rem;background:#2e2820;border:1px solid #5a4830;border-radius:5px;padding:.45rem .75rem;width:100%;box-sizing:border-box}.search-selected-name{font-weight:600;font-size:.9rem;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.search-selected-nip05{font-size:.72rem;color:#a89060;white-space:nowrap}.search-clear{background:none;border:none;color:#a89060;cursor:pointer;font-size:.85rem;padding:0;flex-shrink:0;line-height:1}.search-clear:hover{color:#e8d8b0}.playing-screen{max-width:none;align-items:center}.game-header{display:flex;flex-direction:column;align-items:center;gap:.4rem;margin-bottom:.75rem;width:100%;max-width:600px}.game-status{font-size:1.2rem;font-weight:600}.waiting{color:#a89060;font-style:italic}.user-card{display:flex;align-items:center;gap:.5rem}.user-card-body{display:flex;flex-direction:column;gap:.1rem;min-width:0}.user-card-label{font-size:.72rem;color:#a89060;line-height:1}.user-card-name{font-size:.9rem;font-weight:600;color:#e8d8b0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-card-lg .user-card-name{font-size:1rem}.user-nip05{font-size:.72rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.nip05-valid{color:#6dbf6d}.nip05-unverified{color:#a89060}.user-npub{font-size:.62rem;color:#7a6040;word-break:break-all;white-space:normal;line-height:1.4;font-family:monospace}.avatar-img{border-radius:50%;object-fit:cover;flex-shrink:0}.avatar-fallback{border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;flex-shrink:0}.game-players{display:flex;align-items:center;gap:1rem;margin-bottom:.4rem}.game-vs{font-size:.8rem;color:#a89060}.npub{font-family:monospace;font-size:.85em;color:#c8a870}.pname{font-weight:700}.p1-color{color:#ff6b6b}.p2-color{color:#6b8eff}.wall-summary{display:flex;align-items:center;gap:.5rem;font-size:.8rem;margin-bottom:.5rem}.wall-summary-sep,.wall-summary-label{color:#5a4830}.board{background:#b8832a;padding:14px;border:8px solid #52300a;border-radius:4px;box-shadow:0 10px 40px #000000b3,inset 0 1px #ffd27840;display:inline-flex;flex-direction:column}.row{display:flex}.cell{flex-shrink:0;position:relative;box-sizing:border-box}.cell.square{width:var(--sq);height:var(--sq);background:#f0d878;border:1px solid rgba(0,0,0,.07);cursor:default}.cell.square.hint{background:#9ed870;cursor:pointer}.cell.square.hint:hover{background:#80c850}.cell.square.p1:after,.cell.square.p2:after{content:"";position:absolute;inset:calc(var(--sq) * .115);border-radius:50%;box-shadow:0 2px 6px #00000080}.cell.square.p1:after{background:radial-gradient(circle at 38% 34%,#f99,#c11)}.cell.square.p2:after{background:radial-gradient(circle at 38% 34%,#99f,#12c)}.cell.wall-v{width:var(--gap);height:var(--sq);background:#dfc45a;cursor:pointer}.cell.wall-v:hover{background:#c8aa3a}.cell.wall-h{width:var(--sq);height:var(--gap);background:#dfc45a;cursor:pointer}.cell.wall-h:hover{background:#c8aa3a}.cell.corner{width:var(--gap);height:var(--gap);background:#d4b84e}.cell.wall-v.wall-placed,.cell.wall-h.wall-placed,.cell.corner.wall-placed{background:#1a0804}.cell.wall-preview,.cell.wall-preview:hover{background:#72c030;cursor:pointer}.cell.wall-preview-bad,.cell.wall-preview-bad:hover{background:#c43030;cursor:not-allowed}.game-footer{display:flex;gap:.75rem;margin-top:1.25rem;width:100%;max-width:480px}.game-footer .btn{flex:1}.btn-resign{color:#f88;border-color:#7a3030}.btn-resign:hover{background:#3a1010;border-color:#c44}.last-move{font-size:.78rem;color:#7a6040;font-style:italic}.board-wrap{--sq: min(52px, calc((100vw - 100px) / 10.23));--gap: calc(var(--sq) * .154);display:flex;flex-direction:column;align-items:flex-start;gap:2px}.board-inner{display:flex;flex-direction:row;align-items:flex-start;gap:4px}.board-col-labels{display:flex;flex-direction:row;gap:var(--gap);padding-left:calc(1.2rem + 26px)}.board-row-labels{display:flex;flex-direction:column;gap:var(--gap);width:1.2rem;padding-top:22px}.coord-label{font-size:.65rem;color:#a89060;text-align:center;line-height:1;width:var(--sq);height:var(--sq);display:flex;align-items:center;justify-content:center;flex-shrink:0}.board-row-labels .coord-label{width:1.2rem;height:var(--sq)}.nsec-section{display:flex;flex-direction:column;gap:.6rem;width:100%}.nsec-toggle{background:none;border:none;color:#7a6040;font-size:.8rem;cursor:pointer;padding:0;text-align:center}.nsec-panel{display:flex;flex-direction:column;gap:.6rem;width:100%}.nsec-info{font-size:.78rem;color:#a89060;background:#221a0c;border:1px solid #4a3a18;border-radius:5px;padding:.5rem .65rem;margin:0;line-height:1.4}.nsec-warning{font-size:.78rem;color:#c8882a;background:#2a1e0a;border:1px solid #7a4a10;border-radius:5px;padding:.5rem .65rem;margin:0;line-height:1.4}.nsec-reveal-panel{display:flex;flex-direction:column;gap:.5rem;margin-top:.25rem}.nsec-reveal-row{display:flex;gap:.4rem;align-items:center}.nsec-reveal-value{font-size:.7rem;word-break:break-all;color:#e8c880;flex:1}
