*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}:before,:after{--tw-content: ""}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji";font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}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;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]{display:none}*,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }.container{width:100%}@media (min-width: 640px){.container{max-width:640px}}@media (min-width: 768px){.container{max-width:768px}}@media (min-width: 1024px){.container{max-width:1024px}}@media (min-width: 1280px){.container{max-width:1280px}}@media (min-width: 1536px){.container{max-width:1536px}}.absolute{position:absolute}.relative{position:relative}.-right-2{right:-.5rem}.-top-2{top:-.5rem}.-top-40{top:-10rem}.bottom-10{bottom:2.5rem}.left-0{left:0}.left-1\/2{left:50%}.left-40{left:10rem}.right-36{right:9rem}.right-40{right:10rem}.top-0{top:0}.top-1\/2{top:50%}.top-10{top:2.5rem}.top-2\/3{top:66.666667%}.mx-auto{margin-left:auto;margin-right:auto}.ml-2{margin-left:.5rem}.flex{display:flex}.table{display:table}.h-2{height:.5rem}.h-48{height:12rem}.h-8{height:2rem}.h-screen{height:100vh}.w-1\/3{width:33.333333%}.w-2{width:.5rem}.w-2\/3{width:66.666667%}.w-48{width:12rem}.w-\[60\%\]{width:60%}.-translate-x-1\/2{--tw-translate-x: -50%;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.-translate-y-1\/2{--tw-translate-y: -50%;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.gap-0\.5{gap:.125rem}.rounded-full{border-radius:9999px}.rounded-lg{border-radius:.5rem}.rounded-br{border-bottom-right-radius:.25rem}.border-2{border-width:2px}.border-amber-50{--tw-border-opacity: 1;border-color:rgb(255 251 235 / var(--tw-border-opacity))}.border-blue-500{--tw-border-opacity: 1;border-color:rgb(59 130 246 / var(--tw-border-opacity))}.border-gray-300{--tw-border-opacity: 1;border-color:rgb(209 213 219 / var(--tw-border-opacity))}.bg-blue-500{--tw-bg-opacity: 1;background-color:rgb(59 130 246 / var(--tw-bg-opacity))}.bg-green-500{--tw-bg-opacity: 1;background-color:rgb(34 197 94 / var(--tw-bg-opacity))}.bg-orange-500{--tw-bg-opacity: 1;background-color:rgb(249 115 22 / var(--tw-bg-opacity))}.bg-white{--tw-bg-opacity: 1;background-color:rgb(255 255 255 / var(--tw-bg-opacity))}.p-2{padding:.5rem}.p-4{padding:1rem}.px-2{padding-left:.5rem;padding-right:.5rem}.px-4{padding-left:1rem;padding-right:1rem}.py-1{padding-top:.25rem;padding-bottom:.25rem}.text-center{text-align:center}.text-3xl{font-size:1.875rem;line-height:2.25rem}.text-lg{font-size:1.125rem;line-height:1.75rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xs{font-size:.75rem;line-height:1rem}.font-bold{font-weight:700}.text-blue-500{--tw-text-opacity: 1;color:rgb(59 130 246 / var(--tw-text-opacity))}.text-red-500{--tw-text-opacity: 1;color:rgb(239 68 68 / var(--tw-text-opacity))}.text-white{--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity))}.text-yellow-500{--tw-text-opacity: 1;color:rgb(234 179 8 / var(--tw-text-opacity))}.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)}:root{--tile-w: 56px;--tile-h: 80px;--tile-gap: 2px;--rack-pad-x: 5px;--rack-width: calc((var(--tile-w) * 15) + (var(--tile-gap) * 14) + (var(--rack-pad-x) * 2));--rack-height: calc((var(--tile-h) * 2) + 24px)}body{background-color:#075846;background-image:url(/assets/table-felt.svg);background-position:center;background-size:cover;min-height:100vh;overflow:hidden}.game-board{position:relative;width:100vw;min-height:100vh;min-height:100dvh;height:100vh;height:100dvh;overflow:hidden;background-image:radial-gradient(circle at 50% 38%,rgba(255,255,255,.1),transparent 36%),linear-gradient(180deg,#0000000a,#0000002e)}.rack:before,.rack:after{content:"";position:absolute;top:-3px;bottom:-4px;width:12px;background-image:url(/assets/rack-wood.svg);background-position:center;background-size:cover;border:1px solid rgba(32,16,6,.72);border-radius:7px 7px 0 0;box-shadow:inset 0 1px #ffefbc38,0 5px 14px #00000061}.rack:before{left:-10px}.rack:after{right:-10px}.tile{width:var(--tile-w);height:var(--tile-h);background-color:#f7edd8;background-image:url(/assets/tile-face.svg);background-position:center;background-size:100% 100%;border-color:#5f49296b;box-shadow:inset 0 1px #ffffffc7,inset 0 -2px 5px #64441c33,0 3px 7px #00000042;display:flex;align-items:center;justify-content:center;overflow:hidden;border-width:2px;border-radius:.5rem;cursor:pointer;touch-action:manipulation;transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.2s;flex-shrink:0}.emptyTile{width:var(--tile-w);height:var(--tile-h);background-color:#20120a;background-image:url(/assets/tile-slot.svg);background-position:center;background-size:100% 100%;border:1px solid rgba(245,190,116,.16);box-shadow:inset 0 4px 10px #0000006b,inset 0 -1px #ffe1a01f;display:flex;align-items:center;justify-content:center;opacity:.88;overflow:hidden;border-radius:.5rem;cursor:pointer;touch-action:manipulation;transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.2s;flex-shrink:0}.tile .text-center,.emptyTile .text-center{width:100%}.tile-text{font-size:clamp(11px,calc(var(--tile-w) * .52),30px)!important;line-height:1.05;text-shadow:0 1px 0 rgba(255,255,255,.56),0 2px 3px rgba(83,57,24,.16)}.drag-preview-layer{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999;pointer-events:none}.drag-preview-position{position:absolute;left:0;top:0}.drag-preview-tile{opacity:.96;transform:rotate(-4deg) scale(1.08);box-shadow:inset 0 1px #ffffffd1,inset 0 -2px 5px #64441c33,0 12px 22px #0000005c}.tile-row{display:flex;justify-content:center;gap:var(--tile-gap)}.tile-row-bottom{position:relative;margin-top:6px;padding-top:8px}.tile-row-bottom:before{content:"";position:absolute;left:0;right:0;top:0;height:4px;background:linear-gradient(180deg,#ffdb892e,#170a04c2),url(/assets/rack-wood.svg);background-position:center;background-size:100% 260px;border-top:1px solid rgba(41,18,7,.8);border-bottom:1px solid rgba(255,221,146,.16);box-shadow:0 2px 5px #0000005c}.tile-container{display:flex;flex-direction:column;padding-top:.25rem;padding-bottom:.25rem;gap:var(--tile-gap);padding-left:var(--rack-pad-x);padding-right:var(--rack-pad-x)}.rack{position:fixed;bottom:0;left:50%;--tw-translate-x: -50%;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));width:var(--rack-width);background-color:#7a431c;background-image:url(/assets/rack-wood.svg);background-position:center;background-size:100% 100%;border-color:#251207e6;box-shadow:inset 0 1px #ffecb43d,inset 0 -5px 16px #1007036b,0 -8px 30px #00000061;overflow:visible;display:flex;justify-content:center;border-width:2px;border-top-left-radius:.5rem;border-top-right-radius:.5rem}.rack-sort-button{position:absolute}@media (max-width: 767px){.stack-tiles .rack-sort-button.-top-2.-right-2{top:-6px;right:-6px;padding:2px 6px;font-size:10px}}.rack-sort-button{top:50%;--tw-translate-y: -50%;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));height:calc(100% - 18px);min-height:76px;width:72px;border:0;border-radius:10px;background-color:#dec092;background-image:url(/assets/sort-button.svg);background-position:center;background-size:100% 100%;box-shadow:0 7px 16px #00000057,inset 0 1px #ffffff94;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:900;line-height:1;color:#2f1b0d;text-shadow:0 1px 0 rgba(255,244,215,.78),0 2px 3px rgba(55,26,9,.2);transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s;z-index:30;isolation:isolate}.rack-sort-button:before{content:"";position:absolute;left:10px;right:10px;top:50%;height:34px;transform:translateY(-50%);background:linear-gradient(180deg,#fffae9e6,#cb9f62bd),url(/assets/tile-face.svg);background-position:center;background-size:cover;border:1px solid rgba(86,48,18,.36);border-radius:5px;box-shadow:inset 0 1px #ffffffd1,inset 0 -2px 4px #502b0e38,0 2px 5px #2a120638;z-index:0}.rack-sort-label{position:relative;z-index:1}.rack-sort-button:hover{filter:brightness(1.06)}.rack-sort-button:active{filter:brightness(.96);box-shadow:0 2px 8px #00000057,inset 0 2px 6px #58361538}.rack-sort-left{left:-86px}.rack-sort-right{right:-86px}.stack-pile-row{display:flex;align-items:center;gap:16px}.player-throw{position:absolute;display:flex;z-index:18}.thrown-tiles-stack{display:flex;flex-direction:column;gap:2px}.player-throw-0{top:65%;right:10rem}.player-throw-1{top:2.5rem;right:10rem}.player-throw-2{top:2.5rem;left:10rem}.player-throw-3{top:65%;left:10rem}.player-seat{position:absolute;z-index:22}.player-seat-0{left:50%;bottom:25%;transform:translate(-50%)}.player-seat-1{right:0;top:40%;transform:translateY(-50%) rotate(90deg)}.player-seat-2{left:50%;top:5%;transform:translate(-50%)}.player-seat-3{left:0;top:40%;transform:translateY(-50%) rotate(90deg)}.player-name-badge{min-width:9rem;display:flex;align-items:center;justify-content:center;padding:8px 16px;background:#000000bf;border-radius:999px;color:#fff;font-weight:800;line-height:1}.player-name-text{min-width:0;text-overflow:ellipsis;white-space:nowrap}.join-screen{position:fixed;top:0;right:0;bottom:0;left:0;z-index:35;display:flex;align-items:center;justify-content:center;padding:24px;background:radial-gradient(circle at 50% 38%,rgba(36,159,124,.26),transparent 36%),#031f1c38}.join-panel{width:min(360px,calc(100vw - 40px));display:flex;flex-direction:column;align-items:stretch;gap:14px;padding:22px;background:linear-gradient(135deg,#ffffff14,#fff0),#042c26b8;border:1px solid rgba(196,238,210,.18);border-radius:8px;box-shadow:0 22px 52px #00000061,inset 0 1px #ffffff21;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.join-tile-mark{width:74px;height:96px;margin:-58px auto 0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;background-color:#f7edd8;background-image:url(/assets/tile-face.svg);background-position:center;background-size:100% 100%;border:2px solid rgba(95,73,41,.42);border-radius:10px;box-shadow:inset 0 1px #ffffffc7,inset 0 -2px 5px #64441c33,0 12px 24px #0000004d;color:#ef4444;font-weight:900}.join-tile-mark span:first-child{font-size:25px;line-height:1;color:#1d1710}.join-tile-mark span:last-child{font-size:24px;line-height:1}.join-copy{text-align:center}.join-copy h1{margin:0;color:#fff9e8;font-size:28px;font-weight:900;line-height:1.08}.join-copy p{margin:7px 0 0;color:#def6ebc7;font-size:13px;font-weight:700}.join-field{display:flex;flex-direction:column;gap:7px}.join-field span{color:#fff9e8d1;font-size:12px;font-weight:800}.join-field input{height:52px;width:100%;background:linear-gradient(180deg,#ffffffbd,#e9d5b3b8),url(/assets/tile-face.svg);background-position:center;background-size:cover;border:1px solid rgba(89,55,22,.44);border-radius:7px;box-shadow:inset 0 2px 4px #ffffffb3,inset 0 -2px 5px #623b142e,0 5px 13px #0003;color:#241608;font-size:18px;font-weight:800;outline:none;padding:0 14px}.join-field input::-moz-placeholder{color:#37230f7a}.join-field input::placeholder{color:#37230f7a}.join-field input:focus{border-color:#fabe56f2;box-shadow:0 0 0 3px #f59e0b38,inset 0 2px 4px #ffffffb3,0 8px 18px #0000003d}.join-error{min-height:34px;display:flex;align-items:center;justify-content:center;padding:8px 10px;background:#7f1d1d8a;border:1px solid rgba(252,165,165,.34);border-radius:6px;color:#fee2e2;font-size:13px;font-weight:800;text-align:center}.join-submit{height:54px;background:linear-gradient(180deg,#fff1c933,#3618084d),url(/assets/rack-wood.svg);background-position:center;background-size:cover;border:1px solid rgba(32,16,6,.82);border-radius:7px;box-shadow:inset 0 1px #ffefbc40,inset 0 -3px 9px #1007035c,0 10px 22px #00000042;color:#fff7e4;cursor:pointer;font-size:16px;font-weight:900;text-shadow:0 2px 3px rgba(0,0,0,.48);transition:transform .15s ease,filter .15s ease,box-shadow .15s ease}.join-submit:hover:not(:disabled){filter:brightness(1.08);transform:translateY(-1px)}.join-submit:active:not(:disabled){transform:translateY(1px);box-shadow:inset 0 2px 8px #1007036b,0 5px 14px #0000003d}.join-submit:disabled{cursor:not-allowed;filter:grayscale(.45) brightness(.82)}.join-actions{display:grid;grid-template-columns:1fr;gap:10px}.join-submit-secondary{height:46px;background:linear-gradient(180deg,#fffae9eb,#cda061db),url(/assets/tile-face.svg);background-position:center;background-size:cover;border-color:#5937167a;color:#2f1b0d;text-shadow:0 1px 0 rgba(255,244,215,.76)}.turn-timer-badge{margin-left:7px;min-width:34px;height:22px;display:inline-flex;align-items:center;justify-content:center;background:linear-gradient(180deg,#fffae9f2,#e0bc82e6),url(/assets/tile-face.svg);background-position:center;background-size:cover;border:1px solid rgba(86,48,18,.38);border-radius:999px;box-shadow:inset 0 1px #ffffffdb,0 2px 5px #00000038;color:#2f1b0d;font-size:12px;font-weight:900;line-height:1}.fullscreen-button{position:fixed;right:12px;top:max(10px,env(safe-area-inset-top));z-index:60;display:none;align-items:center;justify-content:center;height:32px;padding:0 12px;background:linear-gradient(180deg,#fffae9f5,#e0bc82eb),url(/assets/tile-face.svg);background-position:center;background-size:cover;border:1px solid rgba(86,48,18,.42);border-radius:999px;box-shadow:inset 0 1px #ffffffdb,0 5px 10px #0000003d;color:#2f1b0d;font-size:12px;font-weight:900;line-height:1;white-space:nowrap}.waiting-banner,.spectator-banner{position:fixed;left:50%;top:18px;z-index:45;max-width:min(860px,calc(100vw - 24px));display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:9px;transform:translate(-50%);padding:10px 16px;background:linear-gradient(135deg,#ffffff1a,#fff0),#03241fd1;border:1px solid rgba(204,246,223,.18);border-radius:999px;box-shadow:0 12px 24px #0000004d,inset 0 1px #ffffff1f;color:#fff9e8;font-size:14px;font-weight:900;line-height:1;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.spectator-banner{min-width:230px}.waiting-room-code,.waiting-host-label{height:28px;display:inline-flex;align-items:center;justify-content:center;padding:0 12px;background:#0214126b;border:1px solid rgba(204,246,223,.14);border-radius:999px;color:#fff9e8;font-size:12px;font-weight:900;line-height:1;white-space:nowrap}.waiting-count{width:28px;height:28px;display:inline-flex;align-items:center;justify-content:center;background:linear-gradient(180deg,#fffae9f2,#e0bc82e6),url(/assets/tile-face.svg);background-position:center;background-size:cover;border:1px solid rgba(86,48,18,.38);border-radius:7px;box-shadow:inset 0 1px #ffffffdb,0 3px 7px #0000003d;color:#2f1b0d}.waiting-cancel,.waiting-start{height:28px;margin-left:4px;display:inline-flex;align-items:center;justify-content:center;padding:0 12px;background:linear-gradient(180deg,#fffae9f0,#e0bc82e6),url(/assets/tile-face.svg);background-position:center;background-size:cover;border:1px solid rgba(86,48,18,.42);border-radius:999px;box-shadow:inset 0 1px #ffffffdb,0 3px 7px #00000038;color:#2f1b0d;font-size:12px;font-weight:900;line-height:1;white-space:nowrap}.waiting-start{background:linear-gradient(180deg,#fff1c933,#3618084d),url(/assets/rack-wood.svg);background-position:center;background-size:cover;border-color:#201006d1;color:#fff7e4;text-shadow:0 2px 3px rgba(0,0,0,.48)}.waiting-start:disabled{cursor:not-allowed;filter:grayscale(.45) brightness(.82)}.waiting-cancel:hover,.waiting-start:hover:not(:disabled){filter:brightness(1.06)}.waiting-cancel:active,.waiting-start:active:not(:disabled){filter:brightness(.95)}.waiting-error-inline{flex-basis:100%;color:#fecaca;font-size:12px;font-weight:800;line-height:1.2;text-align:center}.stack-tiles{position:fixed;left:50%;top:50%;--tw-translate-x: -50%;--tw-translate-y: -50%;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));z-index:20;background-color:#03282370;background-image:linear-gradient(135deg,#ffffff1f,#fff0);border:1px solid rgba(203,244,220,.16);--tw-backdrop-blur: blur(4px);-webkit-backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia);border-radius:.75rem;padding:1rem;--tw-shadow: 0 20px 25px -5px rgb(0 0 0 / .1), 0 8px 10px -6px rgb(0 0 0 / .1);--tw-shadow-colored: 0 20px 25px -5px var(--tw-shadow-color), 0 8px 10px -6px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.finish-drop-label{position:absolute;left:50%;bottom:-28px;transform:translate(-50%);min-width:54px;height:24px;display:flex;align-items:center;justify-content:center;padding:0 10px;background:linear-gradient(180deg,#fffae9f5,#e0bc82eb),url(/assets/tile-face.svg);background-position:center;background-size:cover;border:1px solid rgba(86,48,18,.4);border-radius:999px;box-shadow:inset 0 1px #ffffffdb,0 4px 8px #0000003d;color:#2f1b0d;font-size:12px;font-weight:900;line-height:1;pointer-events:none}.finish-banner{position:absolute;left:50%;top:-48px;transform:translate(-50%);min-width:184px;display:flex;align-items:center;justify-content:center;gap:10px;padding:10px 16px;background:linear-gradient(180deg,#fffae9f5,#e0bc82eb),url(/assets/tile-face.svg);background-position:center;background-size:cover;border:1px solid rgba(86,48,18,.42);border-radius:999px;box-shadow:inset 0 1px #ffffffdb,0 8px 18px #00000047;color:#2f1b0d;font-size:14px;font-weight:900;line-height:1;white-space:nowrap}.restart-game-button{height:28px;display:inline-flex;align-items:center;justify-content:center;padding:0 12px;background:linear-gradient(180deg,#fff1c933,#3618084d),url(/assets/rack-wood.svg);background-position:center;background-size:cover;border:1px solid rgba(32,16,6,.72);border-radius:999px;box-shadow:inset 0 1px #ffefbc40,0 3px 7px #00000038;color:#fff7e4;font-size:12px;font-weight:900;line-height:1;text-shadow:0 2px 3px rgba(0,0,0,.42)}.finish-error{position:absolute;left:50%;bottom:-50px;transform:translate(-50%);width:min(320px,80vw);padding:9px 12px;background:#7f1d1dc7;border:1px solid rgba(252,165,165,.42);border-radius:7px;box-shadow:0 8px 18px #0000003d;color:#fee2e2;font-size:12px;font-weight:800;line-height:1.25;text-align:center}@media (max-width: 1023px){:root{--tile-w: clamp(40px, calc((100vw - 72px) / 15), 52px);--tile-h: calc(var(--tile-w) * 1.42)}.rack{max-width:calc(100vw - 72px)}.player-throw-0,.player-throw-1{right:5.5rem}.player-throw-2,.player-throw-3{left:5.5rem}}@media (max-width: 767px){:root{--tile-gap: 1px;--rack-pad-x: 3px;--tile-w: clamp(19px, calc((100vw - 30px) / 15), 38px);--tile-h: calc(var(--tile-w) * 1.45);--rack-height: calc((var(--tile-h) * 2) + 18px)}.game-board{padding-top:max(8px,env(safe-area-inset-top));padding-bottom:max(4px,env(safe-area-inset-bottom))}.fullscreen-button{display:inline-flex}.tile,.emptyTile{border-radius:5px}.tile-text{font-size:clamp(10px,calc(var(--tile-w) * .56),16px)!important;line-height:1!important}.tile-row-bottom{margin-top:2px;padding-top:4px}.tile-row-bottom:before{height:2px}.tile-container{padding-top:3px;padding-bottom:3px}.rack{width:var(--rack-width);max-width:calc(100vw - 8px);bottom:env(safe-area-inset-bottom);border-radius:7px 7px 0 0}.rack:before,.rack:after{display:none}.rack-sort-button{top:-34px;height:30px;min-height:30px;width:54px;border-radius:7px;font-size:11px;transform:none}.rack-sort-button:before{left:7px;right:7px;height:22px;border-radius:4px}.rack-sort-left{left:4px}.rack-sort-right{right:4px}.stack-tiles{top:43%;padding:8px;border-radius:10px}.stack-pile-row{gap:8px}.stack-tiles .absolute.-top-2.-right-2{top:-6px;right:-6px;padding:2px 6px;font-size:10px}.finish-banner{top:-40px;min-width:150px;padding:8px 12px;font-size:12px;gap:8px}.restart-game-button{height:24px;padding:0 9px;font-size:11px}.finish-drop-label{bottom:-24px;height:21px;min-width:46px;padding:0 8px;font-size:11px}.finish-error{bottom:-44px;width:min(270px,calc(100vw - 24px));padding:7px 9px;font-size:11px}.player-name-badge{min-width:0;max-width:110px;padding:7px 10px;font-size:12px;white-space:nowrap}.turn-timer-badge{min-width:28px;height:19px;margin-left:5px;font-size:10px}.player-seat-0{bottom:calc(var(--rack-height) + 44px + env(safe-area-inset-bottom))}.player-seat-1{right:-26px;top:37%;transform:translateY(-50%)}.player-seat-2{top:max(8px,env(safe-area-inset-top))}.player-seat-3{left:-26px;top:37%;transform:translateY(-50%)}.player-throw-0{top:auto;right:10px;bottom:calc(var(--rack-height) + 6px + env(safe-area-inset-bottom))}.player-throw-1{top:max(14px,calc(env(safe-area-inset-top) + 14px));right:10px}.player-throw-2{top:max(14px,calc(env(safe-area-inset-top) + 14px));left:10px}.player-throw-3{top:auto;left:10px;bottom:calc(var(--rack-height) + 6px + env(safe-area-inset-bottom))}.waiting-banner,.spectator-banner{top:max(8px,env(safe-area-inset-top));width:calc(100vw - 16px);max-width:none;gap:6px;padding:8px;border-radius:10px;font-size:12px;line-height:1.1}.waiting-room-code,.waiting-host-label,.waiting-cancel,.waiting-start{height:25px;padding:0 9px;font-size:11px}.waiting-count{width:25px;height:25px;font-size:12px}.join-screen{padding:16px}}@media (max-width: 1023px) and (max-height: 620px) and (orientation: landscape){:root{--tile-gap: 1px;--rack-pad-x: 3px;--tile-w: clamp(28px, calc((100vw - 96px) / 15), 40px);--tile-h: calc(var(--tile-w) * 1.36);--rack-height: calc((var(--tile-h) * 2) + 16px)}.stack-tiles{top:34%;bottom:auto;padding:6px;transform:translate(-50%,-50%)}.fullscreen-button{display:inline-flex;right:8px;height:28px;padding:0 10px;font-size:11px}@media (display-mode: standalone),(display-mode: fullscreen){.fullscreen-button{display:none}}.player-seat-0{bottom:calc(var(--rack-height) + 40px + env(safe-area-inset-bottom))}.player-seat-1,.player-seat-3{top:39%}.player-seat-1{right:4px;transform:translateY(-50%) rotate(90deg)}.player-seat-3{left:4px;transform:translateY(-50%) rotate(90deg)}.player-name-badge{max-width:102px;padding:8px 9px;font-size:11px}.player-seat-0 .player-name-badge{min-width:132px;max-width:164px}.turn-timer-badge{min-width:27px;height:18px;margin-left:5px;font-size:10px}.player-throw-0,.player-throw-3{top:48%;bottom:auto}}@media (max-width: 360px) and (orientation: portrait){:root{--tile-w: calc((100vw - 30px) / 15)}.player-name-badge{max-width:94px;padding:6px 8px;font-size:11px}.stack-tiles{top:41%}}
