*{box-sizing:border-box}html{color-scheme:light}body{margin:0;font-family:Figtree,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#fff;color:#061222}.app{min-height:100vh;background:#f5f5f5;display:flex;flex-direction:row;font-family:Figtree,sans-serif;font-optical-sizing:auto}.app--version-banner-visible{padding-top:3rem}.app__nav{max-width:204px;width:100%;flex-shrink:0;background-color:#fff;border-right:1px solid #e0e0e0;padding:1.5rem 1.25rem;min-height:100vh;display:flex;flex-direction:column}.app__nav-content{flex:1;display:flex;flex-direction:column;align-items:stretch;gap:1rem}.app__nav-brand{display:flex;flex-direction:column;gap:4px}.app__nav-title{margin:0;font-size:1.5rem;font-weight:700;letter-spacing:-.03em;color:#061222;font-family:Figtree,sans-serif;font-optical-sizing:auto}.app__nav-title--link{padding:0;border:none;background:none;cursor:pointer;text-align:left}.app__nav-difficulties{display:flex;flex-direction:column;align-items:stretch;gap:.5rem}.app__nav-actions{display:flex;flex-direction:column;gap:.5rem}.app__nav-difficulty-label{font-size:1rem;font-weight:600;letter-spacing:-.02em;color:#061222}.app__nav-difficulty-select{width:100%;padding:.75rem 2.5rem .75rem 1rem;font-size:1rem;font-family:Figtree,sans-serif;font-optical-sizing:auto;font-weight:550;color:#061222;background-color:#e4edf6;border:1px solid #E4EDF6;border-radius:8px;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23061222' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center}.app__nav-difficulty-select:hover{background-color:#dae4f0}.app__nav-difficulty-select:focus{outline:none;border-color:#4f3bf4}.app__nav-join-btn{padding:.75rem 1.5rem;font-size:1rem;font-weight:600;letter-spacing:-.02em;border:0;background-color:#4f3bf4;color:#fff;border-radius:6px;cursor:pointer;transition:all .2s ease;margin-bottom:auto}.app__nav-join-btn:hover{background-color:#4331d1}.app__nav-join-btn--secondary{background-color:#fff;color:#4f3bf4;border:1px solid #4F3BF4}.app__nav-join-btn--secondary:hover{background-color:#4f3bf40f}.app__nav-players{flex:1;min-height:0;overflow:auto}.app__nav-footer{margin:0;font-size:.9rem;color:#061222}.app__nav-footer-link{color:#4331d1;text-decoration:none;font-weight:600;transition:opacity .2s ease}.app__nav-footer-link:hover{opacity:.8;text-decoration:underline}.app__main{flex:1;display:flex;flex-direction:column;min-width:0}.app__subheader{display:flex;align-items:center;gap:1rem;padding-bottom:2rem;flex-wrap:nowrap}.app__subheader-title{margin:0;font-size:1.5rem;font-weight:600;color:#333;flex-shrink:0}.app__subheader-controls{flex:1;display:flex;flex-wrap:nowrap;align-items:center;gap:.75rem}.app__subheader-code-text{font-family:Roboto Mono,monospace;font-weight:700;font-size:1.125rem;color:#4f3bf4;letter-spacing:.05em}.app__copy-code-trigger{display:inline-flex;align-items:center;gap:.5rem;padding:.25rem .5rem;border:none;background:none;cursor:pointer;border-radius:6px;transition:background-color .2s ease;font:inherit}.app__copy-code-trigger:hover{background-color:#4f3bf414}.app__copy-icon{width:20px;height:20px;display:block}.app__subheader-messages{width:100%;display:flex;flex-direction:column;gap:.5rem}.app__button--restart{background-color:#fff;color:#ff9800;padding:.5rem .75rem;font-size:.875rem;border:1px solid #ff9800;border-radius:6px;cursor:pointer;transition:0s;font-weight:700;font-family:Figtree,sans-serif;min-width:100px}.app__button--restart:hover:not(:disabled){background-color:#ff9800;color:#fff}.app__button--restart:disabled{opacity:.5;cursor:not-allowed}.app__copy-code-wrapper{position:relative;display:inline-block}.app__notification{position:absolute;top:100%;left:50%;transform:translate(-50%);margin-top:.5rem;background-color:#05ab0d;color:#fff;padding:.5rem 1rem;border-radius:6px;z-index:1000;white-space:nowrap;font-size:.875rem;animation:slideDown .3s ease-out}.app__notification:after{content:"";position:absolute;bottom:100%;left:50%;transform:translate(-50%);border:6px solid transparent;border-bottom-color:#05ab0d}@keyframes slideDown{0%{transform:translate(-50%) translateY(-10px);opacity:0}to{transform:translate(-50%) translateY(0);opacity:1}}.app__container{max-width:1024px;margin:0 auto;background-color:#fff;border-left:1px solid #e0e0e0;border-right:1px solid #e0e0e0;border-radius:0;flex:1 1 auto;width:100%}.app__container--game{padding:1rem 2rem;display:flex;gap:2rem;align-items:flex-start}.app__game-content{flex:1;display:flex;flex-direction:column}.app__create-section{display:flex;flex-direction:column;gap:1rem;margin-bottom:1.5rem}.app__field{display:flex;flex-direction:column;gap:.5rem}.app__label{font-weight:600;color:#333;font-size:.875rem}.app__text-input{padding:.75rem;font-size:1rem;border:2px solid #ccc;border-radius:6px;transition:border-color .2s ease}.app__text-input:focus{outline:none;border-color:#2196f3}.app__button--primary{background-color:#2196f3;color:#fff}.app__button--primary:hover:not(:disabled){background-color:#1976d2;transform:translateY(-2px)}.app__button--secondary{background-color:#f44336;color:#fff}.app__button--secondary:hover{background-color:#d32f2f;transform:translateY(-2px)}.app__button:disabled{opacity:.5;cursor:not-allowed}.app__divider{text-align:center;margin:2rem 0;color:#666;font-weight:600;position:relative}.app__divider:before,.app__divider:after{content:"";position:absolute;top:50%;width:40%;height:1px;background-color:#ccc}.app__divider:before{left:0}.app__divider:after{right:0}.app__game-layout{flex:1;display:flex;flex-direction:column}.app__main-content{flex:1;display:flex;flex-direction:column;align-items:center;width:100%}.app__completion-message{width:100%;height:35px;display:flex;align-items:center;justify-content:center;gap:1rem;padding:0 1rem;background:linear-gradient(180deg,#4caf50,#45a049);color:#fff;border-radius:4px}.app__completion-title{margin:0;font-size:1rem;font-weight:700}.app__completion-time{font-size:1.25rem;font-weight:600;display:flex;align-items:center;gap:.5rem}.app__completion-time .timer__display{color:#fff;font-size:1rem}.app__game-area{display:flex;gap:2rem;align-items:flex-start;justify-content:center;width:100%}.app__game-area--digit-active .game-board{cursor:crosshair}.app__game-controls{display:flex;flex-direction:column;align-items:center;gap:1.5rem;min-width:200px}.app__controls{margin-top:0;width:100%}.app__toggle{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-weight:500;color:#333;width:100%}.app__toggle input[type=checkbox]{width:20px;height:20px;cursor:pointer}.app__font-size-buttons{display:flex;gap:.5rem;margin-top:.75rem}.app__font-size-btn{flex:1;padding:.5rem;font-size:1rem;font-weight:600;border:1px solid #9f9f9f;background-color:#fff;color:#061222;border-radius:6px;cursor:pointer;transition:all .2s ease;font-family:Figtree,sans-serif}.app__font-size-btn:hover{background-color:#f0f0f0;border-color:#4f3bf4;color:#4f3bf4}.app__reconnecting{padding:.5rem 1rem;background-color:#e3f2fd;color:#1565c0;border-radius:6px;text-align:center;font-weight:500;width:100%}.app__error{padding:.5rem 1rem;background-color:#ffc8d1;color:#c62828;border-radius:6px;text-align:center;font-weight:500;width:100%}.app__new-version-banner{position:fixed;top:0;left:0;right:0;z-index:10001;display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:.75rem;padding:.5rem 1rem;background-color:#4f3bf4;color:#fff;font-weight:500;box-shadow:0 2px 12px #0612222e}.app__new-version-banner-actions{display:flex;align-items:center;gap:.5rem}.app__new-version-banner-btn{padding:.35rem .75rem;border-radius:6px;font-weight:600;cursor:pointer;font-family:Figtree,sans-serif;border:1px solid transparent;transition:background-color .2s ease,color .2s ease,border-color .2s ease}.app__new-version-banner-btn--primary{background-color:#fff;color:#4f3bf4;border-color:#fff}.app__new-version-banner-btn--primary:hover{background-color:#e4edf6;border-color:#e4edf6}.app__new-version-banner-btn--cancel{background-color:transparent;color:#fff;border-color:#ffffffa6}.app__new-version-banner-btn--cancel:hover{background-color:#ffffff1f;border-color:#fff}.timer{display:flex;flex-direction:column;align-items:center;gap:.25rem}.timer__label{font-size:.875rem;font-weight:500;color:#666}.timer__display{font-size:1rem;font-weight:500;font-variant-numeric:tabular-nums;color:#4f3bf4;font-family:Figtree,sans-serif}.room-code-input{margin-bottom:1.5rem}.room-code-input__form{display:flex;flex-direction:column;gap:1rem}.room-code-input__field{display:flex;flex-direction:column;gap:.5rem}.room-code-input__label{font-weight:600;color:#333;font-size:.875rem}.room-code-input__text-input{padding:.75rem;font-size:1rem;border:2px solid #ccc;border-radius:6px;transition:border-color .2s ease}.room-code-input__text-input:focus{outline:none;border-color:#2196f3}.room-code-input__text-input--code{font-family:Roboto Mono,monospace;font-size:1.25rem;font-weight:600;letter-spacing:.2em;text-align:center;text-transform:uppercase}.room-code-input__button{padding:.75rem 1.5rem;font-size:1rem;font-weight:600;border:none;background-color:#2196f3;color:#fff;border-radius:6px;cursor:pointer;transition:all .2s ease}.room-code-input__button:hover:not(:disabled){background-color:#1976d2;transform:translateY(-2px)}.room-code-input__button:disabled{opacity:.5;cursor:not-allowed}.room-code-input__display{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:1rem;background-color:#e3f2fd;border-radius:8px}.room-code-input__code{font-family:Roboto Mono,monospace;font-size:2rem;font-weight:700;letter-spacing:.2em;color:#2196f3}.join-room-modal{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.join-room-modal__content{background-color:#fff;border-radius:12px;padding:2rem;width:90%;max-width:400px;position:relative;box-shadow:0 10px 40px #0000004d;animation:slideUpModal .3s ease}@keyframes slideUpModal{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.join-room-modal__close{position:absolute;top:32px;right:32px;background:none;border:none;font-size:2rem;line-height:1;color:#061222;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s ease}.join-room-modal__close:hover{background-color:#f5f5f5;color:#333}.join-room-modal__title{margin:0 0 1.5rem;font-size:1.5rem;font-weight:600;color:#061222;text-align:left}.join-room-modal__form{display:flex;flex-direction:column;gap:1rem}.join-room-modal__field{display:flex;flex-direction:column;gap:.5rem}.join-room-modal__label{font-weight:600;color:#061222;font-size:.875rem}.join-room-modal__input{padding:.75rem;font-size:1rem;border:1px solid #9f9f9f;border-radius:6px;transition:border-color .2s ease}.join-room-modal__input:focus{outline:none;border-color:#4f3bf4}.join-room-modal__input--code{font-family:Roboto Mono,monospace;font-size:1rem;font-weight:500;text-align:left}.join-room-modal__button{padding:.75rem 1.5rem;font-size:1rem;font-weight:600;border:none;background-color:#4f3bf4;color:#fff;border-radius:6px;cursor:pointer;transition:all .2s ease;margin-top:.5rem}.join-room-modal__button:hover:not(:disabled){background-color:#4331d1}.join-room-modal__button:disabled{opacity:.5;cursor:not-allowed}.cell{aspect-ratio:1;min-width:0;min-height:0;border:.5px solid #b1b1b1;display:flex;align-items:center;justify-content:center;cursor:pointer;-webkit-user-select:none;user-select:none;transition:all .1s ease;background-color:#fff;position:relative;overflow:hidden}.cell:hover{background-color:#f5f5f5}.cell--prefilled{background-color:#e8e8e8;font-weight:700;color:#061222;cursor:pointer}.cell--prefilled:hover{background-color:#d8d8d8}.cell--highlighted{background-color:#bacaff}.cell--highlighted:hover,.cell--prefilled.cell--highlighted:hover{background-color:#a8bfff}.cell--conflict,.cell--highlighted.cell--conflict{background-color:#ffddd8;color:#c62828}.cell--conflict:hover{background-color:#ffc9c0;color:#b71c1c}.cell--conflict:hover .cell__value{color:#b71c1c}.cell--highlighted.cell--conflict:hover{background-color:#ffc9c0;color:#b71c1c}.cell--highlighted.cell--conflict:hover .cell__value{color:#b71c1c}.cell__value{font-size:var(--cell-digit-font-size, 1.75rem);font-weight:400;color:#2a3647}.cell--prefilled .cell__value{font-weight:600;color:#061222}.cell__candidates{display:grid;grid-template-columns:repeat(3,1fr);grid-template-rows:repeat(3,1fr);width:100%;height:100%;font-size:.6rem;padding:2px}.cell__candidate{display:flex;align-items:center;justify-content:center;color:#6f818f}.cell__candidate--visible{color:#6f818f;font-weight:500}.number-selector{display:flex;flex-direction:column;align-items:center;gap:1rem}.number-selector__entry-mode{display:flex;width:100%;max-width:300px;border:1px solid #4f3bf4;border-radius:8px;overflow:hidden;background-color:#fff}.number-selector__entry-segment{flex:1;padding:.55rem .75rem;font-size:.95rem;font-weight:600;font-family:Figtree,sans-serif;border:none;background-color:#fff;color:#4f3bf4;cursor:pointer;transition:background-color .2s ease,color .2s ease}.number-selector__entry-segment+.number-selector__entry-segment{border-left:1px solid #4f3bf4}.number-selector__entry-segment:hover{background-color:#4f3bf414}.number-selector__entry-segment--active,.number-selector__entry-segment--active:hover{background-color:#4f3bf4;color:#fff}.number-selector__digit-group{display:flex;flex-direction:column;gap:8px}.number-selector__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem;max-width:300px}.number-selector__button{width:60px;height:60px;font-size:1.75rem;border:1px solid #4F3BF4;background-color:#fff;color:#4f3bf4;border-radius:8px;cursor:pointer;transition:all .2s ease;-webkit-user-select:none;user-select:none;font-family:Figtree,sans-serif;font-optical-sizing:auto;font-weight:600;font-style:normal}.number-selector__button:hover:not(:disabled){background-color:#4f3bf4;color:#fff}.number-selector__button:active:not(:disabled){transform:scale(.95)}.number-selector__button:disabled{opacity:.5;cursor:not-allowed}.number-selector__button--selected{background-color:#4f3bf4;color:#fff}.number-selector__button--complete{opacity:.5}.number-selector__clear-digit{width:100%;height:60px;padding:0 1rem;display:flex;align-items:center;justify-content:center;font-size:1rem;border:1px solid #4F3BF4;background-color:#fff;color:#4f3bf4;border-radius:8px;cursor:pointer;transition:all .2s ease;-webkit-user-select:none;user-select:none;font-family:Figtree,sans-serif;font-optical-sizing:auto;font-weight:600;font-style:normal}.number-selector__clear-digit:hover:not(:disabled){background-color:#4f3bf4;color:#fff}.number-selector__clear-digit:disabled{opacity:.5;cursor:not-allowed}.number-selector__clear-digit--selected{background-color:#4f3bf4;color:#fff}.number-selector__clear{width:100%;padding:.75rem 2rem;font-size:1rem;border:1px solid #f44336;background-color:#fff;color:#f44336;border-radius:8px;cursor:pointer;transition:all .2s ease;-webkit-user-select:none;user-select:none;font-family:Figtree,sans-serif;font-optical-sizing:auto;font-weight:600;font-style:normal}.number-selector__clear:hover:not(:disabled){background-color:#f44336;color:#fff}.number-selector__clear:disabled{opacity:.5;cursor:not-allowed}.number-selector__undo{width:100%;padding:.75rem 2rem;font-size:1rem;border:1px solid #2196f3;background-color:#fff;color:#2196f3;border-radius:8px;cursor:pointer;transition:all .2s ease;-webkit-user-select:none;user-select:none;font-family:Figtree,sans-serif;font-optical-sizing:auto;font-weight:600;font-style:normal;margin-top:.5rem}.number-selector__undo:hover:not(:disabled){background-color:#2196f3;color:#fff}.number-selector__undo:disabled{opacity:.5;cursor:not-allowed}.player-list{min-width:150px;max-width:250px}.player-list__title{margin:0 0 1rem;font-size:1.25rem;font-weight:600;color:#061222}.player-list__item{margin-bottom:1rem;background-color:#fff;border-radius:8px;transition:all .2s ease}.player-list__item:last-child{margin-bottom:0}.player-list__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem;gap:8px}.player-list__name-container{display:flex;align-items:center;gap:.5rem;flex:1}.player-list__name{font-weight:600;color:#061222;flex:1}.player-list__edit-btn{background:none;border:none;cursor:pointer;font-size:1rem;padding:.25rem;opacity:.6;transition:opacity .2s ease;display:flex;align-items:center;justify-content:center}.player-list__edit-btn:hover{opacity:1}.player-list__name-input{flex:1;padding:.25rem .5rem;font-size:.9rem;font-weight:600;border:2px solid #2196f3;border-radius:4px;color:#061222;background-color:#fff;font-family:inherit}.player-list__name-input:focus{outline:none;border-color:#1976d2;box-shadow:0 0 0 3px #2196f31a}.difficulty-selector{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1.5rem}.difficulty-selector__label{font-weight:600;color:#333;font-size:1rem}.difficulty-selector__options{display:flex;flex-wrap:wrap;gap:.5rem}.difficulty-selector__button{padding:.5rem 1rem;font-size:.875rem;font-weight:500;border:2px solid #2196f3;background-color:#fff;color:#2196f3;border-radius:6px;cursor:pointer;transition:all .2s ease}.difficulty-selector__button:hover{background-color:#e3f2fd;transform:translateY(-2px)}.difficulty-selector__button--selected{background-color:#2196f3;color:#fff}.difficulty-selector__button--selected:hover{background-color:#1976d2}.progress-bar{width:100%;margin-bottom:.5rem}.progress-bar__label{font-size:.875rem;font-weight:500;margin-bottom:.25rem;color:#666}.progress-bar__container{width:100%;height:20px;background-color:#eceef1;border-radius:10px;overflow:hidden;position:relative}.progress-bar__fill{height:100%;background:#4331d1;transition:width .3s ease;border-radius:10px}.game-board{display:grid;grid-template-columns:repeat(9,minmax(0,1fr));grid-template-rows:repeat(9,minmax(0,1fr));gap:0;border:2px solid #061222;width:100%;aspect-ratio:1;margin:0 auto;min-height:0}.cell--thick-right{border-right:2px solid #061222!important}.cell--thick-bottom{border-bottom:2px solid #061222!important}@media (max-width: 768px){.app{flex-direction:column}.app__nav{max-width:none;width:100%;min-height:0;border-right:none;border-bottom:1px solid #e0e0e0;padding:1rem}.app__nav-content{flex:none;flex-direction:column;flex-wrap:wrap;gap:1rem;align-items:center}.app__nav-brand{flex:1 1 100%}.app__nav-difficulties{flex:1;flex-direction:row;min-width:0;align-items:center}.app__nav-actions{flex-direction:row;align-items:center;gap:.5rem}.app__nav-join-btn{margin-top:0}.app__subheader{flex-direction:column;align-items:flex-start;gap:1rem}.app__subheader-controls,.app__subheader .app__button--share{width:100%}.app__container{padding:1rem}.app__game-layout{flex-direction:column}.app__game-area{flex-direction:column;align-items:center}.app__game-controls{width:100%;max-width:600px}.number-selector,.number-selector__digit-group{width:100%}.number-selector__grid{max-width:100%;grid-template-columns:repeat(5,1fr)}}
