/*! tailwindcss v4.1.5 | MIT License | https://tailwindcss.com */@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,::backdrop,:after,:before{--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-space-y-reverse:0;--tw-border-style:solid;--tw-font-weight:initial;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial}}}@layer theme{:host,:root{--font-sans:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji";--font-mono:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;--color-yellow-100:oklch(97.3% .071 103.193);--color-yellow-400:oklch(85.2% .199 91.936);--color-yellow-700:oklch(55.4% .135 66.442);--color-blue-600:oklch(54.6% .245 262.881);--color-gray-200:oklch(92.8% .006 264.531);--color-gray-400:oklch(70.7% .022 261.325);--color-gray-600:oklch(44.6% .03 256.802);--color-white:#fff;--spacing:.25rem;--text-lg:1.125rem;--text-lg--line-height:calc(1.75/1.125);--text-2xl:1.5rem;--text-2xl--line-height:calc(2/1.5);--font-weight-semibold:600;--font-weight-bold:700;--animate-spin:spin 1s linear infinite;--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4,0,.2,1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,::backdrop,:after,:before{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}:host,html{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,pre,samp{font-family:var(--default-mono-font-family,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}menu,ol,ul{list-style:none}audio,canvas,embed,iframe,img,object,svg,video{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,optgroup,select,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab,red,red)){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit,::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-day-field,::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-hour-field,::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-millisecond-field,::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.sr-only{clip:rect(0,0,0,0);white-space:nowrap;border-width:0;width:1px;height:1px;margin:-1px;padding:0;overflow:hidden}.absolute,.sr-only{position:absolute}.fixed{position:fixed}.relative{position:relative}.static{position:static}.inset-0{inset:calc(var(--spacing)*0)}.z-50{z-index:50}.container{width:100%}@media (min-width:40rem){.container{max-width:40rem}}@media (min-width:48rem){.container{max-width:48rem}}@media (min-width:64rem){.container{max-width:64rem}}@media (min-width:80rem){.container{max-width:80rem}}@media (min-width:96rem){.container{max-width:96rem}}.mb-2{margin-bottom:calc(var(--spacing)*2)}.mb-4{margin-bottom:calc(var(--spacing)*4)}.mb-6{margin-bottom:calc(var(--spacing)*6)}.mb-12{margin-bottom:calc(var(--spacing)*12)}.block{display:block}.contents{display:contents}.flex{display:flex}.grid{display:grid}.hidden{display:none}.h-8{height:calc(var(--spacing)*8)}.w-8{width:calc(var(--spacing)*8)}.transform{transform:var(--tw-rotate-x,)var(--tw-rotate-y,)var(--tw-rotate-z,)var(--tw-skew-x,)var(--tw-skew-y,)}.animate-spin{animation:var(--animate-spin)}.cursor-not-allowed{cursor:not-allowed}.resize{resize:both}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.justify-center{justify-content:center}:where(.space-y-3>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing)*3)*var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing)*3)*calc(1 - var(--tw-space-y-reverse)))}.rounded{border-radius:.25rem}.border{border-style:var(--tw-border-style);border-width:1px}.border-yellow-400{border-color:var(--color-yellow-400)}.bg-gray-400{background-color:var(--color-gray-400)}.bg-yellow-100{background-color:var(--color-yellow-100)}.fill-blue-600{fill:var(--color-blue-600)}.p-2{padding:calc(var(--spacing)*2)}.px-4{padding-inline:calc(var(--spacing)*4)}.py-2{padding-block:calc(var(--spacing)*2)}.py-6{padding-block:calc(var(--spacing)*6)}.text-center{text-align:center}.text-2xl{font-size:var(--text-2xl);line-height:var(--tw-leading,var(--text-2xl--line-height))}.text-lg{font-size:var(--text-lg);line-height:var(--tw-leading,var(--text-lg--line-height))}.font-bold{--tw-font-weight:var(--font-weight-bold);font-weight:var(--font-weight-bold)}.font-semibold{--tw-font-weight:var(--font-weight-semibold);font-weight:var(--font-weight-semibold)}.text-gray-200{color:var(--color-gray-200)}.text-white{color:var(--color-white)}.text-yellow-700{color:var(--color-yellow-700)}.lowercase{text-transform:lowercase}.shadow{--tw-shadow:0 1px 3px 0 var(--tw-shadow-color,#0000001a),0 1px 2px -1px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.filter{filter:var(--tw-blur,)var(--tw-brightness,)var(--tw-contrast,)var(--tw-grayscale,)var(--tw-hue-rotate,)var(--tw-invert,)var(--tw-saturate,)var(--tw-sepia,)var(--tw-drop-shadow,)}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,visibility,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}@media (prefers-color-scheme:dark){.dark\:text-gray-600{color:var(--color-gray-600)}}}:root{--grid-size:min(30vw,75vmin);--cell-size:calc(var(--grid-size)/6);--board-background:#2f2f2f;--blocker-color:#ff4c4c;--grid-border:#4a4a4a;--cell-border:#4a4a4a;--can-drop-color:#22c55e26;--cannot-drop-color:#ef444426;--highlight-border-color:#3b82f6;--popup-background:#fffffffa;--popup-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;--primary-color:#3b82f6;--secondary-color:#1e40af;--background-color:#1f003a;--text-color:#fff}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent;margin:0;padding:0}body,html{touch-action:manipulation;-webkit-overflow-scrolling:touch;background-color:var(--background-color);max-width:100vw;height:100%;color:var(--text-color);overflow:hidden auto}body{padding-bottom:env(safe-area-inset-bottom);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}body,main{flex-direction:column;align-items:center;display:flex}main{background:linear-gradient(135deg,#1e0c3b,#4a1c6f);justify-content:flex-start;width:100%;max-width:100%;min-height:100vh;margin:0;padding:1rem;overflow-x:hidden}.game-container{background:#1e0c3bb3;border-radius:1rem;flex-direction:column;max-width:800px;left:0;right:0;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}.board-container,.game-container{align-items:center;padding:.5rem;display:flex;position:relative}.board-container{-webkit-user-select:none;user-select:none;background:#28144699;border-radius:.5rem;justify-content:center;margin:0 auto;box-shadow:0 4px 6px -1px #0000001a}.board-container,.game-grid{width:var(--grid-size);height:var(--grid-size)}.game-grid{border:2px solid var(--grid-border);z-index:1;background-color:#2f2f2f;background-image:radial-gradient(circle,#ffffff0d 1px,#0000 0),radial-gradient(circle,#ffffff08 1px,#0000 0),radial-gradient(circle,#ffffff05 1px,#0000 0);background-position:0 0,2px 2px,1px 1px;background-size:5px 5px,3px 3px,2px 2px;border-radius:.25rem;grid-template-rows:repeat(6,1fr);grid-template-columns:repeat(6,1fr);display:grid}.cell,.game-grid{touch-action:none;position:relative}.cell{border:1px solid var(--cell-border);width:var(--cell-size);height:var(--cell-size);justify-content:center;align-items:center;transition:all .2s cubic-bezier(.4,0,.2,1);display:flex}.cell.can-drop{background-color:var(--can-drop-color);z-index:2;border:2px solid #22c55e;transform:scale(1.03);box-shadow:0 0 12px #22c55e4d}.cell.cannot-drop{background-color:var(--cannot-drop-color);z-index:2;border:2px solid #ef4444;transform:scale(1.03)}.cell.can-drop+.cell.can-drop{box-shadow:0 0 8px #00b400b3}.cell.cannot-drop+.cell.cannot-drop{box-shadow:0 0 8px #ff0000b3}.placed-piece{z-index:5;transition:transform .2s}.piece-preview,.placed-piece{pointer-events:none;position:absolute}.piece-preview{z-index:10;opacity:.7;filter:drop-shadow(0 5px 5px #0000004d);transition:opacity .2s}.pieces-container{touch-action:none;background:#28144680;border-radius:.5rem;flex-wrap:wrap;justify-content:center;gap:1rem;min-height:120px;display:flex;box-shadow:0 4px 6px -1px #0000001a}.piece{cursor:grab;touch-action:none;-webkit-user-select:none;user-select:none;z-index:1;will-change:transform,opacity;filter:drop-shadow(0 4px 6px #0000001a);transition:all .2s cubic-bezier(.4,0,.2,1)}.piece.selected{box-shadow:0 0 0 3px var(--highlight-border-color),0 8px 16px #3b82f64d;z-index:10;transform:scale(1.05)}.piece:active{cursor:grabbing;transform:scale(.98)}.piece img{object-fit:contain;width:100%;height:100%}.pieces-container .placed{opacity:.3;cursor:not-allowed;pointer-events:none}.controls{justify-content:center;gap:1rem;display:none}.control-btn{background-color:var(--primary-color);color:#fff;cursor:pointer;touch-action:manipulation;border:none;border-radius:.5rem;padding:.75rem 1.5rem;font-size:1rem;font-weight:600;transition:all .2s cubic-bezier(.4,0,.2,1);box-shadow:0 4px 6px -1px #3b82f633}.control-btn:hover{background-color:var(--secondary-color);transform:translateY(-1px);box-shadow:0 6px 8px -1px #3b82f64d}.control-btn:active{transform:translateY(1px);box-shadow:0 2px 4px -1px #3b82f633}.piece-draggable{cursor:grab;touch-action:none;-webkit-user-select:none;user-select:none}.piece-draggable:active{cursor:grabbing}.piece-controls{justify-content:center;gap:1rem;width:100%;margin-top:15px;display:none}.win-message{animation:pulse 1.5s infinite alternate;box-shadow:0 4px 12px #0003}@keyframes pulse{50%{opacity:.5}}@media (max-width:768px){:root{--grid-size:min(85vw,85vmin)}main{padding:.5rem}.game-container{width:100%;max-width:100%}.controls{flex-wrap:wrap}.pieces-container{gap:1rem}.control-btn{padding:.75rem 1.25rem;font-size:1rem}.piece-controls{flex-direction:row;justify-content:space-around;width:100%;margin-top:1.5rem}.piece-controls .control-btn{flex:1;max-width:150px}.coord-label{font-size:8px!important}}@media (max-width:480px){:root{--grid-size:min(80vw,80vmin)}main{padding:.25rem}.game-container{width:100%;max-width:100%}.board-container{margin:0 auto;padding:.75rem}.controls{margin-top:1rem}.controls,.pieces-container{gap:.75rem}.piece{max-width:70px;max-height:70px}.congrats-popup{padding:1.5rem}.congrats-popup h2{margin-bottom:1rem;font-size:1.8rem}.congrats-popup p{margin-bottom:1.25rem;font-size:1rem}.congrats-buttons{flex-direction:column;gap:.75rem;width:100%;margin-top:1.5rem}.congrats-button{width:100%;padding:.75rem 1rem}.congrats-time-result{margin:.75rem 0;font-size:1.2rem}}.congrats-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;pointer-events:auto;background:#00000080;justify-content:center;align-items:center;animation:fadeIn .3s ease-out;display:flex;position:fixed;inset:0}.congrats-popup{text-align:center;width:400px;max-width:90%;color:var(--text-color);pointer-events:auto;z-index:1001;background:#3c1e64f2;border:1px solid #30cfcf4d;border-radius:1rem;padding:2rem;animation:scaleIn .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden;box-shadow:0 15px 30px #0009,0 0 20px #30cfcf66}.congrats-popup h2{color:#30cfcf;margin-bottom:1.5rem;padding-top:.5rem;font-size:2rem;font-weight:700}.congrats-popup p{color:var(--text-color);margin-bottom:1.5rem;font-size:1.1rem;line-height:1.5}.congrats-buttons{flex-direction:column;align-items:center;gap:12px;width:100%;display:flex}.congrats-button{cursor:pointer;color:#000;pointer-events:auto;background-color:#30cfcf;border:none;border-radius:.5rem;padding:.75rem 1.5rem;font-size:1rem;font-weight:600;transition:all .2s cubic-bezier(.4,0,.2,1);box-shadow:0 4px 6px -1px #0003}.congrats-button:hover{background-color:#38efef;transform:translateY(-1px);box-shadow:0 6px 8px -1px #0000001a}.congrats-button:active{transform:translateY(1px);box-shadow:0 2px 4px -1px #0000001a}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes scaleIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.congrats-popup:after,.congrats-popup:before{content:"";border-radius:50%;width:10px;height:10px;animation:confetti 2s infinite;position:absolute}.congrats-popup:before{background-color:#fc0;top:-20px;left:30%}.congrats-popup:after{background-color:#0070f3;animation-delay:.5s;top:-15px;right:30%}@keyframes confetti{0%{opacity:1;transform:translateY(0)rotate(0)}to{opacity:0;transform:translateY(-100px)rotate(2turn)}}.confetti-container{pointer-events:none;z-index:999;width:100%;height:100%;position:fixed;top:0;left:0;overflow:hidden}.confetti-particle{opacity:0;pointer-events:none;border-radius:50%;width:10px;height:10px;animation:confettiFall 3s ease-in-out infinite;position:absolute}@keyframes confettiFall{0%{opacity:1;transform:translateY(-100vh)rotate(0)}50%{opacity:1}to{opacity:0;transform:translateY(100vh)rotate(2turn)}}.unselect-button{background-color:var(--primary-color);color:#fff;cursor:pointer;text-transform:uppercase;letter-spacing:.5px;opacity:1;visibility:visible;border:none;border-radius:.5rem;justify-content:center;align-items:center;width:auto;height:2.5rem;margin:0 auto;padding:.5rem 1rem;font-size:.9rem;font-weight:600;transition:all .2s;display:flex;position:relative;box-shadow:0 2px 4px #0003}.unselect-button.hidden{opacity:0;visibility:hidden;pointer-events:none}.unselect-button:hover{background-color:var(--secondary-color);transform:translateY(-1px);box-shadow:0 4px 6px #0003}.unselect-button:active{transform:translateY(1px);box-shadow:0 1px 2px #0003}@media (max-width:768px){.unselect-button{height:2.25rem;padding:.4rem .8rem;font-size:.85rem}}@media (max-width:480px){.unselect-button{height:2rem;padding:.35rem .7rem;font-size:.8rem}}.main-container{flex-direction:column;justify-content:center;align-items:center;min-height:100vh;padding:2rem;display:flex}@media (max-width:768px){.main-container{padding:1rem}}@media (max-width:480px){.main-container{padding:1.5rem .5rem .75rem}.congrats-overlay{justify-content:center;align-items:center}}.menu-container{text-align:center;background:#1e0c3bcc;border-radius:1rem;flex-direction:column;width:100%;max-width:400px;max-height:650px;padding:2rem;display:flex;position:relative;overflow:hidden;box-shadow:0 4px 6px #0000001a}.menu-container h1{color:#333;margin-bottom:2rem;font-size:2.5rem}.menu-buttons{flex-direction:row;justify-content:center;gap:1rem;display:flex}.menu-button{cursor:pointer;border-radius:.5rem;flex:1;max-width:200px;padding:1rem 2rem;font-size:1.2rem;transition:transform .2s,background-color .2s}.menu-button:hover{transform:translateY(-2px)}@media (max-width:480px){.menu-buttons{flex-direction:row;gap:.5rem}.menu-button{padding:.75rem 1rem;font-size:1rem}}.game-container{width:100%;max-width:1200px;margin:0 auto}.game-header{justify-content:space-between;align-items:center;width:100%;margin-top:.5rem;margin-bottom:1rem;padding:.5rem;display:flex}.game-header .logo{justify-content:flex-start;align-items:center;width:120px;height:40px;display:flex}.game-header .logo picture,.game-header .logo picture img{width:100%;height:100%}.timer-display{color:var(--primary-color);text-align:center;z-index:100;background:#3b82f61a;border-radius:.5rem;min-width:100px;padding:.35rem 1rem;font-size:1.3rem;font-weight:600;position:relative}.game-header .back-button{color:#fff;cursor:pointer;background-color:#dc2626;border:none;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;margin-left:auto;padding:0;font-size:1.2rem;font-weight:700;transition:all .2s;display:flex}.game-header .back-button:hover{background-color:#b91c1c;transform:scale(1.05)}.game-header .back-button:active{transform:scale(.95)}.game-content{align-items:flex-start;gap:.5rem}.game-content,.popup-overlay{justify-content:center;display:flex}.popup-overlay{z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background-color:#000000b3;align-items:center;width:100%;height:100%;position:fixed;top:0;left:0}.popup-content{text-align:center;background:linear-gradient(135deg,#1e0c3bf2,#3c1e64f2);border:1px solid #30cfcf4d;border-radius:12px;width:90%;max-width:340px;padding:25px;animation:popup-fade-in .3s ease-out;position:relative;box-shadow:0 15px 30px #0009,0 0 20px #30cfcf66}.popup-close-button{color:#fff;cursor:pointer;z-index:10;background:#ff5555e6;border:none;border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;padding:0;font-size:20px;line-height:1;transition:all .2s;display:flex;position:absolute;top:10px;right:10px}.popup-close-button:hover{background:#f55;transform:scale(1.1)}.popup-close-button:active{transform:scale(.95)}@keyframes popup-fade-in{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.popup-content h3{color:#30cfcf;margin-top:0;margin-bottom:20px;font-size:1.5rem;font-weight:600}.popup-buttons{flex-direction:column;align-items:center;gap:12px;display:flex}.popup-buttons button{width:80%;padding:12px 0}.primary-button{color:#000;cursor:pointer;background-color:#30cfcf;border:none;border-radius:.5rem;padding:.75rem 1.5rem;font-size:1rem;transition:background-color .2s}.primary-button:hover{background-color:#38efef}.secondary-button{color:#fff;cursor:pointer;background-color:#436;border-radius:.5rem;padding:.75rem 1.5rem;font-size:1rem;transition:background-color .2s}.secondary-button:hover{background-color:#7a5db5}.opponent-list{width:100%;max-width:400px;color:var(--text-color);z-index:5;background:#3c1e64f2;border:1px solid #30cfcf4d;border-radius:1rem;padding:2rem;position:relative;box-shadow:0 15px 30px #0009,0 0 20px #30cfcf66}.opponent-list-header{justify-content:space-between;align-items:center;margin-bottom:1.5rem;display:flex}.opponent-list-header h2{color:var(--text-color);margin:0;font-size:1.5rem;font-weight:600}.close-button{color:var(--text-color);cursor:pointer;background:0 0;border:none;border-radius:50%;margin:-.5rem;padding:.5rem;font-size:2rem;line-height:1;transition:all .2s}.close-button:hover{color:#30cfcf;background-color:#ffffff1a}.logout-button{width:100%;margin-bottom:1rem}.opponent-list ul{margin:0;padding:0;list-style:none}.opponent-list li{margin-bottom:.5rem}.opponent-button{cursor:pointer;width:100%;color:var(--text-color);background:#3c1e5a99;border:1px solid #ffffff1a;border-radius:.5rem;justify-content:space-between;align-items:center;padding:1rem;transition:all .2s;display:flex}.opponent-button:hover{background-color:#5a3282cc;transform:translateY(-2px);box-shadow:0 4px 8px #0003}.status-dot{background-color:#30cfcf;border-radius:50%;width:8px;height:8px;margin-left:.5rem}.opponent-list-description{background-color:#3c1e5a66;border:1px solid #ffffff1a;border-radius:.5rem;margin-bottom:1.5rem;padding:1rem}.opponent-list-description p{color:var(--text-color);margin:0;font-size:.95rem;line-height:1.5}.logo-container{flex-shrink:0;justify-content:center;align-items:center;margin-bottom:.5rem;display:flex}.logo-image{object-fit:contain;max-width:100%;height:auto;max-height:180px}.logo-banderole{text-align:center;background:linear-gradient(135deg,#d4af37,#a67c00);border:1px solid #f0d078;border-radius:1.5rem;width:45%;margin:0 auto 1.2rem;padding:.2rem .8rem;transition:all .2s;display:none;box-shadow:0 1px 3px #0003}.logo-banderole:hover{background:linear-gradient(135deg,#e6c144,#b38600);transform:translateY(-1px);box-shadow:0 2px 4px #0000004d}.logo-banderole:active{transform:translateY(1px);box-shadow:0 1px 2px #0000004d}.leaderboard-link{color:#000;cursor:pointer;justify-content:center;align-items:center;gap:.3rem;margin:0 auto;font-size:.75rem;font-weight:600;text-decoration:none;display:flex}.leaderboard-link:after{content:"🏆";font-size:.85rem}.tagline{color:#ffffffe6;text-align:center;letter-spacing:.2px;font-size:1rem;font-weight:400;line-height:1.4}.controls-info,.tagline{max-width:90%;margin:0 auto .6rem}.controls-info{color:#fffc;background:#1e0c3b80;border-radius:.5rem;padding:.75rem;font-size:.85rem}.controls-title{color:#30cfcf;font-size:.9rem;font-weight:600}.controls-info ul{margin:0;padding:.5rem 0 0;list-style-type:none}.controls-info li{text-align:left;margin-bottom:.5rem;padding-left:1rem;position:relative}.controls-info li:before{content:"•";color:#30cfcf;position:absolute;left:0}.countdown{text-align:center}.countdown-number{color:#4caf50;margin:1rem 0;font-size:4rem;font-weight:700}.score-display{color:#666;margin:1rem 0;font-size:1.2rem}@media (max-width:768px){.game-content{flex-direction:column;align-items:center}.menu-container{padding:1rem}.menu-button{padding:.75rem 1.5rem}.timer-display{position:absolute;left:50%;transform:translate(-50%)}.game-header{position:relative}}.username-input{border:2px solid #ffc93c;border-radius:.5rem;width:100%;margin:1rem 0;padding:1rem;font-size:1.2rem;transition:border-color .2s}.username-input:focus{border-color:#ffc93c;outline:none;box-shadow:0 0 0 2px #4caf5033}.error-message{color:#dc2626;text-align:left;margin:.5rem 0;font-size:.875rem}.waiting-message{text-align:center;color:#718096;margin:1rem 0;font-style:italic}.version-number{color:#9370db;opacity:.7;z-index:10;font-size:12px;position:fixed;bottom:10px;right:10px}.congrats-time-result{color:#30cfcf;background:#30cfcf1a;border-radius:.5rem;margin:1rem 0;padding:.5rem 1rem;font-size:1.4rem;font-weight:600;display:inline-block}.challenge-label{color:#ff9770;margin-right:5px;font-weight:600}.challenge-tries{color:#fdff6a;opacity:.8;margin-left:5px;font-size:.8em}.challenge-lost-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;pointer-events:auto;background:#000000b3;justify-content:center;align-items:center;animation:fadeIn .3s ease-out;display:flex;position:fixed;inset:0}.challenge-lost-popup{text-align:center;width:400px;max-width:90%;color:var(--text-color);pointer-events:auto;z-index:1001;background:#641e1ef2;border:1px solid #ff64644d;border-radius:1rem;padding:2rem;animation:scaleIn .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden;box-shadow:0 15px 30px #0009,0 0 20px #ff646466}.challenge-lost-popup h2{color:#f55;margin-bottom:1.5rem;padding-top:.5rem;font-size:2rem;font-weight:700}.challenge-lost-popup p{color:var(--text-color);margin-bottom:1.5rem;font-size:1.1rem;line-height:1.5}.challenge-lost-buttons{z-index:1002;pointer-events:auto;justify-content:center;gap:1rem;margin-top:2.5rem;margin-bottom:.5rem;display:flex;position:relative}.challenge-lost-button{cursor:pointer;color:#000;pointer-events:auto;background-color:#30cfcf;border:none;border-radius:.5rem;padding:.75rem 1.5rem;font-size:1rem;font-weight:600;transition:all .2s cubic-bezier(.4,0,.2,1);box-shadow:0 4px 6px -1px #0003}.challenge-lost-button:hover{background-color:#38efef;transform:translateY(-1px);box-shadow:0 6px 8px -1px #0000001a}.challenge-lost-button:active{transform:translateY(1px);box-shadow:0 2px 4px -1px #0000001a}.challenge-intro{text-align:center;background:linear-gradient(135deg,#1e0c3be6,#3c1e64e6);border:2px solid #ff9770;box-shadow:0 0 30px #ff977066}.challenge-title{color:#ff9770;text-shadow:0 2px 4px #0000004d;margin-bottom:1.5rem;font-size:2rem;font-weight:700}.challenge-description{color:#fff;margin-bottom:1.5rem;font-size:1.1rem;line-height:1.3}.challenge-time{color:#fdff6a;background:#fdff6a1a;border-radius:.3rem;margin:0 .25rem;padding:.25rem .75rem;font-size:1.3rem;font-weight:700;display:inline-block}@media (max-width:480px){.challenge-title{margin-bottom:1rem;font-size:1.6rem}.challenge-description{margin-bottom:1rem;font-size:1rem}.challenge-time{padding:.2rem .5rem;font-size:1.1rem}}@media (max-height:700px){.logo-image{max-height:130px}.menu-container{padding:1.5rem}.tagline{margin-bottom:.8rem;font-size:.9rem;line-height:1.3}}@media (max-height:600px){.logo-image{max-height:100px}.menu-container{padding:1rem}.logo-banderole{margin-bottom:.8rem}.tagline{max-width:95%;margin-bottom:.6rem;font-size:.8rem;line-height:1.2}.controls-info{margin-bottom:1rem;padding:.5rem;font-size:.75rem}.controls-info li{margin-bottom:.3rem}}.toggle-view-button{color:#30cfcf;cursor:pointer;background:0 0;border:none;margin:0 auto 1rem;padding:.3rem .6rem;font-size:.8rem;text-decoration:underline;transition:color .2s;display:block}.toggle-view-button:hover{color:#38efef}@media (min-height:601px){.tagline{margin-bottom:.5rem;font-size:.9rem;line-height:1.3}.controls-info{padding:.5rem;font-size:.8rem}.controls-info li{margin-bottom:.25rem}}@media (max-height:600px){.controls-info,.tagline{min-height:4.2rem}}.daily-challenge{background:linear-gradient(135deg,#141e46e6,#3c1e64e6);border:2px solid #30cfcf;box-shadow:0 0 30px #30cfcf66}.daily-date{color:#fdff6a;margin-bottom:1.5rem;font-size:1.2rem;font-weight:500}.daily-challenge-button{color:#1e133a;background-color:#30cfcf;width:100%;margin-top:10px;font-weight:600;position:relative;overflow:visible}.daily-challenge-button:hover{background-color:#38efef}.loading-container{flex-direction:column;justify-content:center;align-items:center;margin:2rem 0;display:flex}.loading-spinner{border:4px solid #ffffff4d;border-top-color:#30cfcf;border-radius:50%;width:40px;height:40px;margin-bottom:1rem;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(1turn)}}.daily-complete{background:linear-gradient(135deg,#141e46f2,#3c1e64f2);border:2px solid #30cfcf;box-shadow:0 0 30px #30cfcf66}.challenge-info{color:#30cfcf;background-color:#30cfcf33;border-radius:4px;margin-right:8px;padding:2px 6px;font-size:.9em;font-weight:600;display:inline-block}.challenge-total-time{opacity:.8;margin-left:5px;font-size:.8em}.daily-challenge-timer{text-align:center;flex-direction:column}.daily-challenge-timer,.daily-timer-row{align-items:center;width:100%;display:flex}.daily-timer-row{justify-content:center}.daily-timer-row:first-child{justify-content:space-between;margin-bottom:4px}.challenge-current-time{color:var(--primary-color);font-size:1.4rem;font-weight:600}.timer-display .challenge-label{color:#ff9770;margin-right:4px;font-size:.95rem;font-weight:600}.timer-display .challenge-info{color:#30cfcf;background-color:#30cfcf33;border-radius:8px;margin:0;padding:2px 8px;font-size:.85rem;font-weight:600}.challenge-total-time{color:#fdff6a;margin-left:6px;font-size:.8rem}@media (max-width:480px){.timer-display{background:#3b82f626;width:auto;min-width:auto;max-width:220px;padding:.5rem .8rem}.challenge-current-time{font-size:1.2rem}.timer-display .challenge-label{font-size:.8rem}.timer-display .challenge-info{padding:1px 6px;font-size:.8rem}.challenge-total-time{font-size:.7rem}}@media (min-width:481px) and (max-width:600px){.timer-display{background:#3b82f626;max-width:240px;padding:.5rem .9rem}.challenge-current-time{font-size:1.3rem}}.error-container{text-align:center;padding:2rem 0}.name-input-container{text-align:left;background:#1e0c3bb3;border-radius:.5rem;margin:1rem 0;padding:1rem}.name-input-container label{color:#fdff6a;margin-bottom:.5rem;font-size:.9rem;display:block}.player-name-input{color:#fff;background:#ffffff12;border:2px solid #30cfcf;border-radius:.5rem;width:100%;padding:.7rem;font-size:1rem;transition:all .2s}.player-name-input:focus{border-color:#38efef;outline:none;box-shadow:0 0 0 2px #30cfcf4d}.player-name-input::placeholder{color:#ffffff80}.name-error{color:#f55;margin-top:.5rem;font-size:.8rem}.leaderboard-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;background:#000000b3;justify-content:center;align-items:center;animation:fadeIn .3s ease-out;display:flex;position:fixed;inset:0}.leaderboard-container{background:linear-gradient(135deg,#141e46f2,#3c1e64f2);border:2px solid #30cfcf;border-radius:1rem;width:500px;max-width:90%;padding:2rem;position:relative;box-shadow:0 15px 30px #0009,0 0 20px #30cfcf66}.leaderboard-header{flex-direction:column;align-items:center;margin-bottom:1.5rem;display:flex;position:relative}.leaderboard-header h2{color:#30cfcf;margin-bottom:.5rem;font-size:1.8rem}.leaderboard-header h3{color:#fdff6a;font-size:1.2rem;font-weight:500}.leaderboard-header .close-button{color:#fff;cursor:pointer;background:#f55;border:none;border-radius:50%;justify-content:center;align-items:center;width:2rem;height:2rem;font-size:1.2rem;transition:all .2s;display:flex;position:absolute;top:-.5rem;right:-.5rem}.leaderboard-header .close-button:hover{background:#f77;transform:scale(1.1)}.leaderboard-entries{max-height:300px;margin:1rem 0;overflow-y:auto}.leaderboard-entries table{border-collapse:collapse;width:100%}.leaderboard-entries td,.leaderboard-entries th{text-align:left;border-bottom:1px solid #ffffff1a;padding:.75rem}.leaderboard-entries th{color:#fdff6a;text-transform:uppercase;letter-spacing:.05em;font-size:.9rem;font-weight:600}.leaderboard-entries td{color:#fff}.leaderboard-entries tr:last-child td{border-bottom:none}.leaderboard-entries .highlighted-entry{background:#30cfcf26;border-radius:.3rem}.your-score{text-align:center;background:#30cfcf1a;border-radius:.5rem;margin:1rem 0;padding:1rem}.your-score p{color:#30cfcf;font-size:1.1rem;font-weight:600}.leaderboard-footer{justify-content:center;margin-top:1.5rem;display:flex}.empty-leaderboard{text-align:center;color:#ffffffb3;padding:2rem 0;font-style:italic}@media (max-width:600px){.leaderboard-container{width:92%;padding:1.5rem}.leaderboard-header h2{font-size:1.3rem}.leaderboard-header h3{font-size:1rem}.leaderboard-entries td,.leaderboard-entries th{padding:.5rem;font-size:.9rem}}.main-leaderboard{max-width:600px}.date-selector{text-align:center;width:100%;margin:.5rem 0 1rem}.date-dropdown{color:#fff;appearance:none;cursor:pointer;text-align:center;background:#1e0c3bb3 url(data:image/svg+xml;charset=US-ASCII,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%22292.4%22%20height%3D%22292.4%22%3E%3Cpath%20fill%3D%22%2330CFCF%22%20d%3D%22M287%2069.4a17.6%2017.6%200%200%200-13-5.4H18.4c-5%200-9.3%201.8-12.9%205.4A17.6%2017.6%200%200%200%200%2082.2c0%205%201.8%209.3%205.4%2012.9l128%20127.9c3.6%203.6%207.8%205.4%2012.8%205.4s9.2-1.8%2012.8-5.4L287%2095c3.5-3.5%205.4-7.8%205.4-12.8%200-5-1.9-9.2-5.5-12.8z%22%2F%3E%3C%2Fsvg%3E) right .7rem top 50%/.65rem no-repeat;border:2px solid #30cfcf;border-radius:.5rem;width:80%;max-width:300px;padding:.5rem 1rem;font-size:1rem}.date-dropdown:focus{border-color:#38efef;outline:none;box-shadow:0 0 0 2px #30cfcf4d}.date-dropdown option{background-color:#1e0c3b}.empty-subtext{opacity:.7;margin-top:.5rem;font-size:.9rem}.logo-banderole{cursor:pointer;display:block}.name-input-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1100;background:#000000b3;justify-content:center;align-items:center;animation:fadeIn .3s ease-out;display:flex;position:fixed;inset:0}.name-input-dialog{text-align:center;background:linear-gradient(135deg,#141e46f2,#3c1e64f2);border:2px solid #30cfcf;border-radius:1rem;width:400px;max-width:90%;padding:2rem;position:relative;box-shadow:0 15px 30px #0009,0 0 20px #30cfcf66}.name-input-dialog h2{color:#30cfcf;margin-bottom:1rem;font-size:1.8rem}.name-input-dialog p{color:#fff;margin-bottom:.5rem;font-size:1.1rem}.dialog-time{color:#fdff6a;background:#fdff6a1a;border-radius:.5rem;margin:1rem 0;padding:.5rem 1rem;font-size:2rem;font-weight:700;display:inline-block}.leaderboard-prompt{margin-top:1.5rem;font-weight:600}.dialog-input{background:0 0;margin:1rem 0 1.5rem;padding:0}.dialog-buttons{justify-content:center;gap:1rem;display:flex}@media (max-width:480px){.name-input-dialog{padding:1.5rem}.dialog-time,.name-input-dialog h2{font-size:1.5rem}}.new-label{color:#1e133a;z-index:5;text-transform:uppercase;letter-spacing:.5px;background-color:#fdff6a;border-radius:3px;padding:3px 8px;font-size:.7rem;font-weight:700;animation:pulse-new 1.5s infinite alternate;position:absolute;top:-10px;right:-10px;transform:rotate(45deg);box-shadow:0 0 5px #fdff6ab3}@keyframes pulse-new{0%{transform:rotate(45deg)scale(1);box-shadow:0 0 5px #fdff6ab3}to{transform:rotate(45deg)scale(1.1);box-shadow:0 0 12px #fdff6ae6}}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-space-y-reverse{syntax:"*";inherits:false;initial-value:0}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-font-weight{syntax:"*";inherits:false}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}