.cell-note-bold{font-weight:700!important;color:#1976d2!important;margin:0 auto;max-width:500px;width:calc(100% - 2rem);box-sizing:border-box}.auth-message{margin-bottom:2rem}.auth-message p{font-size:1.1rem;color:#2c3e50}.auth-buttons{display:flex;gap:1rem;justify-content:center}.btn{padding:clamp(.7rem,2vw,.8rem) clamp(1.2rem,4vw,1.5rem);border:none;border-radius:6px;font-size:clamp(.9rem,2.5vw,1rem);font-weight:600;cursor:pointer;transition:all .2s ease;min-width:clamp(100px,30vw,120px);white-space:nowrap;text-decoration:underline}.auth-form-container{display:flex;flex-direction:column;align-items:center}.game-options{text-align:center}.game-options h2{margin-bottom:2rem;color:#2c3e50}.options-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,150px),1fr));gap:clamp(1rem,5vw,2rem);margin:0 auto;max-width:900px;padding:0 .5rem}.option-card{background-color:#fff;border-radius:12px;padding:clamp(1.5rem,4vw,2rem) clamp(1rem,3vw,1.5rem);box-shadow:0 8px 20px #0000001a;transition:all .3s ease;cursor:pointer;position:relative;display:flex;flex-direction:column;align-items:center;height:60%;min-height:200px}.option-card:hover{transform:translateY(-5px);box-shadow:0 12px 30px #00000026}.option-icon{font-size:clamp(2.5rem,8vw,3rem);margin-bottom:clamp(.8rem,3vw,1rem)}.option-card h3{color:#2c3e50;margin-bottom:.8rem;font-size:clamp(1.1rem,3vw,1.25rem);text-align:center}.option-card p{color:#7f8c8d;font-size:clamp(.85rem,2.5vw,.9rem);text-align:center}.coming-soon-badge{position:absolute;top:10px;right:10px;background-color:#e74c3c;color:#fff;font-size:.7rem;padding:.3rem .6rem;border-radius:10px;font-weight:600}.landing-footer{margin-top:auto;text-align:center;padding-top:2rem;color:#7f8c8d;font-size:.9rem}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh}.spinner{border:4px solid rgba(0,0,0,.1);width:36px;height:36px;border-radius:50%;border-left-color:#3498db;animation:spin 1s linear infinite}.new-game-page{background-color:#f5f7fa;min-height:100vh;padding-bottom:3rem}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;flex-wrap:wrap;padding:0 1rem}.header-actions{display:flex;gap:1rem;flex-wrap:wrap}.user-profile-container{margin:0 auto 2rem;max-width:800px;background-color:#fff;border-radius:10px;box-shadow:0 5px 15px #0000000d;padding:1rem}.new-game-container{display:flex;justify-content:center;align-items:flex-start;gap:2rem;flex-wrap:wrap;padding:0 1rem}.new-game-form-container{flex:1;max-width:600px;min-width:300px;background-color:#fff;border-radius:10px;box-shadow:0 5px 15px #0000000d}.new-game-form{padding:2rem}.new-game-form h2{margin-top:0;margin-bottom:1.5rem;color:#2c3e50;text-align:center}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:#34495e;text-align:left}.id-selection{display:flex;flex-direction:column;gap:1rem}.toggle-container{display:flex;border-radius:6px;overflow:hidden;margin-bottom:.5rem}.toggle-btn{flex:1;padding:.8rem;background-color:#f5f5f5;border:none;cursor:pointer;transition:all .2s ease;font-weight:500}.toggle-btn.active{background-color:#3498db;color:#fff}.id-input-container{display:flex;gap:.5rem}.id-input{flex:1;padding:.8rem;border:1px solid #ddd;border-radius:6px;font-size:1rem;width:100%}.refresh-btn{background-color:#f5f5f5;border:1px solid #ddd;border-radius:6px;width:40px;cursor:pointer;transition:all .2s ease;font-size:1.2rem}.refresh-btn:hover{background-color:#e0e0e0}.form-actions{margin-top:2rem;display:flex;justify-content:center}.submit-btn{width:100%;max-width:300px;padding:1rem;font-size:1.1rem}.difficulty-selector{display:flex;gap:.5rem;flex-wrap:wrap}.difficulty-btn{flex:1;padding:.8rem 1.2rem;border-radius:6px;background-color:transparent;border:2px solid;cursor:pointer;transition:all .2s ease;min-width:100px;font-weight:500}.difficulty-btn:hover{transform:translateY(-2px)}.difficulty-btn.selected{transform:translateY(-2px);box-shadow:0 4px 8px #0000001a}@media screen and (max-width: 768px){.page-header{flex-direction:column;gap:1rem;text-align:center}.header-actions{justify-content:center;width:100%}.difficulty-selector{justify-content:center}.auth-buttons{flex-direction:column;gap:.8rem;width:100%;max-width:300px;margin:0 auto}.auth-buttons button{width:100%}.landing-header h2{font-size:1.5rem}.form-actions{flex-direction:column;gap:.8rem;align-items:center}.form-actions button{width:100%;max-width:300px}.game-options h2{font-size:1.5rem;padding:0 1rem}}@media screen and (max-width: 480px){.landing-header h1{font-size:2rem}.auth-container{padding:1.2rem}.option-card{padding:1.2rem 1rem;min-height:180px}.option-icon{font-size:2.2rem;margin-bottom:.7rem}.option-card h3{font-size:1.1rem;margin-bottom:.5rem}.option-card p{font-size:.85rem}.coming-soon-badge{font-size:.65rem;padding:.2rem .5rem}.auth-form .form-group{margin-bottom:1rem}.auth-input{padding:.7rem;font-size:.95rem}.auth-footer{margin-top:1rem}.btn{padding:.7rem 1.2rem}.btn,.btn-link,.option-card,input[type=submit],button{touch-action:manipulation}}@media screen and (max-width: 360px){.landing-header h1{font-size:1.8rem}.landing-header{margin-bottom:1.5rem}.tagline{font-size:.9rem}.option-card{padding:1rem .8rem;min-height:160px}.option-icon{font-size:2rem;margin-bottom:.6rem}.option-card p{font-size:.8rem}.auth-message p,.auth-input{font-size:.9rem}.landing-footer{font-size:.8rem}}.sudoku-board,.sudoku-row,.sudoku-cell,.game-controls,.number-button-bar{user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;touch-action:manipulation}.game-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;flex-wrap:wrap}.game-header h1{margin:0;flex:1}.back-to-lobby{padding:.5rem 1rem;background-color:#3498db;color:#fff;border:none;border-radius:4px;cursor:pointer;font-weight:500;transition:background-color .2s}.back-to-lobby:hover{background-color:#2980b9}.result-page{max-width:800px;margin:2rem auto;padding:2rem;background-color:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a}.result-page h1{margin-top:0;color:#333}.result-page h2{color:#2196f3}.result-page table{width:100%;margin:1.5rem 0;border-collapse:collapse}.result-page th,.result-page td{padding:.75rem;text-align:left;border-bottom:1px solid #eee}.result-page th{background-color:#f9f9f9;font-weight:500}.result-actions{display:flex;justify-content:center;gap:1rem;margin-top:2rem}.result-actions button{padding:.75rem 1.5rem;border:none;border-radius:4px;font-weight:500;cursor:pointer;transition:background-color .2s}.result-actions button:first-child{background-color:#4caf50;color:#fff}.result-actions button:first-child:hover{background-color:#3d8b40}.lobby-button{background-color:#3498db;color:#fff}.lobby-button:hover{background-color:#2980b9}.user-section{margin-bottom:2rem;padding:1rem;border-radius:8px;background-color:#f5f5f5}.user-profile{display:flex;justify-content:space-between;align-items:center;padding:.5rem}.user-info{display:flex;align-items:center;gap:1rem}.user-avatar{width:40px;height:40px;border-radius:50%;object-fit:cover;border:2px solid #3498db}.username{font-weight:700}.logout-button{padding:.5rem 1rem;background-color:#f44336;color:#fff;border:none;border-radius:4px;cursor:pointer}.auth-options{width:100%}.auth-buttons{display:flex;justify-content:center;gap:1rem}.login-container{margin:0 auto;max-width:400px;padding:1rem;width:100%}.auth-form{width:100%}.auth-input{width:100%;padding:.8rem;font-size:1rem;border:1px solid #ddd;border-radius:6px;transition:border-color .2s ease}.auth-input:focus{border-color:#3498db;outline:none}.auth-footer{margin-top:1.5rem;text-align:center;color:#7f8c8d}.btn-link{background:none;border:none;color:#3498db;cursor:pointer;text-decoration:underline;font-weight:500;padding:0}.btn-link:hover{color:#2980b9}.register-container{max-width:600px}.avatar-preview{display:flex;justify-content:center;margin-top:1rem}.avatar-preview img{border-radius:50%;object-fit:cover;width:60px;height:60px;border:2px solid #3498db}.error-message{background-color:#f8d7da;color:#721c24;padding:.75rem 1.25rem;margin-bottom:1rem;border:1px solid #f5c6cb;border-radius:6px;text-align:center}.form-group{margin-bottom:1rem;text-align:left}.form-group label{display:block;margin-bottom:.5rem;font-weight:500}.form-group input{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:1rem}.register-form{max-width:500px;margin:0 auto;padding:1rem}.form-actions{display:flex;justify-content:space-between;margin-top:1.5rem}.error-message{background-color:#ffebee;color:#d32f2f;padding:1rem;margin:1rem 0;border-radius:4px;border-left:4px solid #d32f2f}.avatar-preview{margin-top:.5rem;text-align:center}.avatar-preview img{border-radius:50%;object-fit:cover}.game-container{display:flex;flex-direction:column;gap:2rem;max-width:1200px;margin:0 auto;padding:0 1rem}@media (min-width: 992px){.game-container{flex-direction:row;align-items:flex-start}.game-section{flex:1}.lobby-section{flex:1.5}}.game-section h2,.lobby-section h2{margin-bottom:1.5rem;color:#333;text-align:center}.game-form{max-width:500px;margin:0 auto;padding:1.5rem;background-color:#f9f9f9;border-radius:8px;box-shadow:0 2px 8px #0000001a}.logo{height:6em;padding:1.5em;will-change:filter;transition:filter .3s}.logo:hover{filter:drop-shadow(0 0 2em #646cffaa)}.logo.react:hover{filter:drop-shadow(0 0 2em #61dafbaa)}@keyframes logo-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (prefers-reduced-motion: no-preference){a:nth-of-type(2) .logo{animation:logo-spin infinite 20s linear}}.card{padding:2em}.read-the-docs{color:#888}.sudoku-board{display:grid;grid-template-rows:repeat(9,1fr);gap:2px;margin:2rem auto;width:min(435px,90vw);height:min(435px,90vw);background:#222;border:3px solid #000;box-sizing:border-box;overflow:hidden;padding-right:1px}.sudoku-row{display:grid;grid-template-columns:repeat(9,1fr);gap:2px}.sudoku-cell{background:#fff;border:3px solid #fff;width:auto;height:auto;aspect-ratio:1/1;display:flex;align-items:center;justify-content:center;font-size:clamp(.9rem,3vw,1.2rem);cursor:pointer;transition:background .2s;position:relative;font-family:Arial,Helvetica,sans-serif;color:#333;box-sizing:border-box}.number-input-circle{display:flex;flex-wrap:wrap;width:min(270px,90vw);height:min(270px,90vw);border-radius:50%;background:#f8f8f8;box-shadow:0 2px 8px #0003;position:absolute;z-index:10;align-items:center;justify-content:center;padding:16px;transform:translate(-50%,-50%)}.number-input-circle button{width:30px;height:30px;margin:4px;border-radius:50%;border:none;background:#e0e0e0;font-size:1rem;cursor:pointer}.number-button-bar button:disabled{background:#ccc;color:#ccc;cursor:not-allowed;opacity:.7}.number-button-bar{display:flex;justify-content:center;flex-wrap:wrap;gap:8px;margin:1rem 0;max-width:100%;padding:0 10px}.game-controls{display:flex;justify-content:center;flex-wrap:wrap;gap:10px;margin:1rem 0;padding:0 10px}.keyboard-shortcuts{max-width:500px;margin:2rem auto;padding:1rem;background-color:#f5f5f5;border-radius:8px;text-align:left}.keyboard-shortcuts h3{color:#333;margin-bottom:.5rem;text-align:center}.keyboard-shortcuts ul{padding-left:1.5rem;list-style-type:disc}.pizza-menu-container{position:fixed;inset:0;display:flex;justify-content:center;align-items:center;z-index:9999;background-color:#00000080;animation:pizza-fade-in .2s forwards;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;touch-action:none;overflow:hidden}.game-lobby{max-width:800px;margin:0 auto 2rem;padding:1rem}.game-lobby h2{margin-bottom:1.5rem;color:#333;text-align:center}.games-list{display:grid;gap:1rem}.game-card{display:flex;justify-content:space-between;align-items:center;padding:1rem;background-color:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;transition:transform .2s,box-shadow .2s}.game-card:hover{transform:translateY(-3px);box-shadow:0 4px 12px #00000026}.game-info{flex:1}.game-info h3{margin:0 0 .5rem;color:#333;font-size:1.2rem}.difficulty-badge{display:inline-block;padding:.25rem .75rem;margin-right:1rem;border-radius:20px;font-size:.85rem;font-weight:500}.player-count{display:inline-block;color:#555;font-size:.9rem}.game-duration{margin:.5rem 0;color:#666;font-size:.9rem}.player-list{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.75rem}.player-name{display:inline-block;padding:.15rem .5rem;background-color:#f0f0f0;border-radius:4px;font-size:.85rem;color:#555}.game-actions{margin-left:1rem}.join-button{padding:.5rem 1.25rem;background-color:#4caf50;color:#fff;border:none;border-radius:4px;font-weight:500;cursor:pointer;transition:background-color .2s}.join-button:hover{background-color:#3d8b40}.loading{text-align:center;padding:2rem;color:#666}@media screen and (max-width: 768px){.game-card{flex-direction:column;align-items:flex-start}.game-actions{margin-left:0;margin-top:1rem;align-self:flex-end}}.pizza-menu{transition:all .2s ease-in-out;animation:pizza-zoom-in .3s forwards;pointer-events:auto}@keyframes pizza-fade-in{0%{opacity:0}to{opacity:1}}@keyframes pizza-zoom-in{0%{transform:scale(.7)}to{transform:scale(1)}}.keyboard-shortcuts li{margin-bottom:.5rem}kbd{background-color:#eee;border-radius:3px;border:1px solid #b4b4b4;box-shadow:0 1px 1px #0003;color:#333;display:inline-block;font-family:monospace;font-size:.85em;font-weight:700;line-height:1;padding:2px 4px;margin:0 .2em}@media screen and (max-width: 768px){h1{font-size:1.7rem;margin:.7rem 0}.cell-notes{font-size:max(8px,1.8vw);padding:0;gap:0}.cell-note-num{font-weight:600;padding:0;margin:0}.keyboard-shortcuts{font-size:.9rem;padding:.8rem;margin:1.5rem auto}.keyboard-shortcuts h3{font-size:1.1rem}.game-form,.register-form{max-width:90%;padding:1rem}}@media screen and (max-width: 480px){#root{padding:1rem .5rem}h1{font-size:1.5rem;margin:.5rem 0}.game-controls button{padding:4px 12px!important;font-size:.9rem!important;margin:6px!important}.sudoku-board{gap:1px;border-width:2px;width:min(100%,95vw);margin-left:auto;margin-right:auto}.sudoku-cell{border-width:2px;padding:0}.cell-notes{font-size:max(7px,1.9vw);gap:0;grid-gap:0}.cell-note-num{font-weight:700;color:#444;margin:0;padding:0}.sudoku-row>div:last-child{border-right-width:2px}.number-input-circle button{width:min(28px,8vw);height:min(28px,8vw);font-size:.9rem;margin:2px}.user-section{padding:.8rem;margin-bottom:1rem}.user-info{gap:.5rem}.keyboard-shortcuts{display:none}}.number-button-bar button{width:min(40px,10vw);height:min(40px,10vw);min-width:32px;min-height:32px;border-radius:8px;border:1px solid #bbb;background:#f0f0f0;font-size:clamp(.9rem,4vw,1.1rem);color:#222;align-content:center;display:flex;align-items:center;justify-content:center;cursor:pointer}.loading-overlay{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;background:#ffffffd9;z-index:9999}.loading-content{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px}.loading-ring{width:140px;height:140px;border-radius:50%;background:radial-gradient(circle at center,#2196f314,#2196f305);position:relative;display:grid;place-items:center;box-shadow:0 8px 24px #2196f340}.spinner{position:absolute;width:400px;height:400px;border-radius:50%;border:4px solid rgba(33,150,243,.2);border-top-color:#2196f3;border-right-color:#2196f3;animation:spin 1.1s linear infinite;z-index:2}.logo{width:300px;height:300px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:1}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.random-background{position:fixed;top:0;left:0;width:100%;height:100%;background-size:cover;background-position:center;background-repeat:no-repeat;opacity:.5;z-index:-1}
