*,: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: }*,: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]:where(:not([hidden=until-found])){display:none}h1,h2,h3,h4,h5,h6{font-family:var(--ui-font-display)}.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}}.pointer-events-none{pointer-events:none}.pointer-events-auto{pointer-events:auto}.\!visible{visibility:visible!important}.visible{visibility:visible}.static{position:static}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.inset-0{inset:0}.inset-2{inset:.5rem}.inset-\[-15px\]{inset:-15px}.-left-2{left:-.5rem}.-left-6{left:-1.5rem}.-right-2{right:-.5rem}.-right-3{right:-.75rem}.-right-6{right:-1.5rem}.-top-14{top:-3.5rem}.-top-2{top:-.5rem}.-top-3{top:-.75rem}.-top-6{top:-1.5rem}.bottom-0{bottom:0}.left-0{left:0}.left-1\/2{left:50%}.left-2{left:.5rem}.left-\[-10\%\]{left:-10%}.right-0{right:0}.right-2{right:.5rem}.right-\[-10\%\]{right:-10%}.top-0{top:0}.top-1\/2{top:50%}.top-2{top:.5rem}.top-\[-20\%\]{top:-20%}.z-0{z-index:0}.z-10{z-index:10}.z-20{z-index:20}.z-30{z-index:30}.z-40{z-index:40}.z-\[-1\]{z-index:-1}.z-\[12000\]{z-index:12000}.z-\[9999\]{z-index:9999}.mb-1{margin-bottom:.25rem}.mb-2{margin-bottom:.5rem}.ml-2{margin-left:.5rem}.mt-0\.5{margin-top:.125rem}.mt-1{margin-top:.25rem}.mt-2{margin-top:.5rem}.mt-3{margin-top:.75rem}.mt-4{margin-top:1rem}.mt-5{margin-top:1.25rem}.mt-6{margin-top:1.5rem}.block{display:block}.flex{display:flex}.inline-flex{display:inline-flex}.table{display:table}.hidden{display:none}.h-1{height:.25rem}.h-10{height:2.5rem}.h-12{height:3rem}.h-16{height:4rem}.h-2{height:.5rem}.h-3{height:.75rem}.h-\[300px\]{height:300px}.h-\[50\%\]{height:50%}.h-full{height:100%}.max-h-\[280px\]{max-height:280px}.min-h-\[140px\]{min-height:140px}.w-10{width:2.5rem}.w-14{width:3.5rem}.w-16{width:4rem}.w-2{width:.5rem}.w-24{width:6rem}.w-3{width:.75rem}.w-6{width:1.5rem}.w-\[200px\]{width:200px}.w-\[220px\]{width:220px}.w-\[340px\]{width:340px}.w-\[60\%\]{width:60%}.w-full{width:100%}.min-w-\[140px\]{min-width:140px}.min-w-\[160px\]{min-width:160px}.min-w-\[210px\]{min-width:210px}.min-w-\[220px\]{min-width:220px}.max-w-6xl{max-width:72rem}.flex-1{flex:1 1 0%}.origin-bottom{transform-origin:bottom}.origin-top-right{transform-origin:top right}.-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))}.translate-x-\[-100\%\]{--tw-translate-x: -100%;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))}.-rotate-1{--tw-rotate: -1deg;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))}.-rotate-12{--tw-rotate: -12deg;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))}.-rotate-2{--tw-rotate: -2deg;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))}.-rotate-3{--tw-rotate: -3deg;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))}.rotate-1{--tw-rotate: 1deg;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))}.rotate-12{--tw-rotate: 12deg;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))}.rotate-180{--tw-rotate: 180deg;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))}.skew-x-\[-10deg\]{--tw-skew-x: -10deg;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))}.skew-x-\[-15deg\]{--tw-skew-x: -15deg;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))}.skew-x-\[-20deg\]{--tw-skew-x: -20deg;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))}.skew-x-\[10deg\]{--tw-skew-x: 10deg;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))}.skew-x-\[15deg\]{--tw-skew-x: 15deg;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))}.skew-y-6{--tw-skew-y: 6deg;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))}.scale-105{--tw-scale-x: 1.05;--tw-scale-y: 1.05;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))}.scale-110{--tw-scale-x: 1.1;--tw-scale-y: 1.1;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))}.scale-95{--tw-scale-x: .95;--tw-scale-y: .95;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))}.scale-\[2\.5\]{--tw-scale-x: 2.5;--tw-scale-y: 2.5;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))}@keyframes bounce{0%,to{transform:translateY(-25%);animation-timing-function:cubic-bezier(.8,0,1,1)}50%{transform:none;animation-timing-function:cubic-bezier(0,0,.2,1)}}.animate-bounce{animation:bounce 1s infinite}@keyframes pulse{50%{opacity:.5}}.animate-pulse{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}@keyframes spin{to{transform:rotate(360deg)}}.animate-spin{animation:spin 1s linear infinite}.cursor-not-allowed{cursor:not-allowed}.cursor-pointer{cursor:pointer}.select-none{-webkit-user-select:none;-moz-user-select:none;user-select:none}.resize{resize:both}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-start{align-items:flex-start}.items-end{align-items:flex-end}.items-center{align-items:center}.justify-end{justify-content:flex-end}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-1{gap:.25rem}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.space-y-2>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.5rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.5rem * var(--tw-space-y-reverse))}.space-y-3>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.75rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.75rem * var(--tw-space-y-reverse))}.self-start{align-self:flex-start}.self-end{align-self:flex-end}.overflow-hidden{overflow:hidden}.overflow-visible{overflow:visible}.overflow-y-auto{overflow-y:auto}.whitespace-nowrap{white-space:nowrap}.whitespace-pre-wrap{white-space:pre-wrap}.rounded-full{border-radius:9999px}.rounded-sm{border-radius:.125rem}.border{border-width:1px}.border-2{border-width:2px}.border-4{border-width:4px}.border-b-2{border-bottom-width:2px}.border-l-4{border-left-width:4px}.border-t{border-top-width:1px}.border-dashed{border-style:dashed}.border-amber-400{--tw-border-opacity: 1;border-color:rgb(251 191 36 / var(--tw-border-opacity, 1))}.border-black{--tw-border-opacity: 1;border-color:rgb(0 0 0 / var(--tw-border-opacity, 1))}.border-black\/20{border-color:#0003}.border-crimson-600{--tw-border-opacity: 1;border-color:rgb(217 0 24 / var(--tw-border-opacity, 1))}.border-gray-400{--tw-border-opacity: 1;border-color:rgb(156 163 175 / var(--tw-border-opacity, 1))}.border-red-500\/60{border-color:#ef444499}.border-white{--tw-border-opacity: 1;border-color:rgb(255 255 255 / var(--tw-border-opacity, 1))}.border-white\/10{border-color:#ffffff1a}.border-white\/20{border-color:#fff3}.border-white\/30{border-color:#ffffff4d}.border-white\/70{border-color:#ffffffb3}.border-yellow-400{--tw-border-opacity: 1;border-color:rgb(250 204 21 / var(--tw-border-opacity, 1))}.bg-\[\#333\]{--tw-bg-opacity: 1;background-color:rgb(51 51 51 / var(--tw-bg-opacity, 1))}.bg-\[\#f0f0f0\]{--tw-bg-opacity: 1;background-color:rgb(240 240 240 / var(--tw-bg-opacity, 1))}.bg-amber-400\/20{background-color:#fbbf2433}.bg-black{--tw-bg-opacity: 1;background-color:rgb(0 0 0 / var(--tw-bg-opacity, 1))}.bg-black\/10{background-color:#0000001a}.bg-black\/60{background-color:#0009}.bg-black\/70{background-color:#000000b3}.bg-black\/80{background-color:#000c}.bg-crimson-600{--tw-bg-opacity: 1;background-color:rgb(217 0 24 / var(--tw-bg-opacity, 1))}.bg-crimson-600\/60{background-color:#d9001899}.bg-gray-200{--tw-bg-opacity: 1;background-color:rgb(229 231 235 / var(--tw-bg-opacity, 1))}.bg-gray-300{--tw-bg-opacity: 1;background-color:rgb(209 213 219 / var(--tw-bg-opacity, 1))}.bg-gray-600{--tw-bg-opacity: 1;background-color:rgb(75 85 99 / var(--tw-bg-opacity, 1))}.bg-gray-700{--tw-bg-opacity: 1;background-color:rgb(55 65 81 / var(--tw-bg-opacity, 1))}.bg-gray-800{--tw-bg-opacity: 1;background-color:rgb(31 41 55 / var(--tw-bg-opacity, 1))}.bg-ink-800{--tw-bg-opacity: 1;background-color:rgb(26 26 26 / var(--tw-bg-opacity, 1))}.bg-red-500{--tw-bg-opacity: 1;background-color:rgb(239 68 68 / var(--tw-bg-opacity, 1))}.bg-white{--tw-bg-opacity: 1;background-color:rgb(255 255 255 / var(--tw-bg-opacity, 1))}.bg-white\/10{background-color:#ffffff1a}.bg-yellow-400{--tw-bg-opacity: 1;background-color:rgb(250 204 21 / var(--tw-bg-opacity, 1))}.bg-gradient-to-t{background-image:linear-gradient(to top,var(--tw-gradient-stops))}.bg-gradient-to-tr{background-image:linear-gradient(to top right,var(--tw-gradient-stops))}.from-black{--tw-gradient-from: #000 var(--tw-gradient-from-position);--tw-gradient-to: rgb(0 0 0 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-transparent{--tw-gradient-from: transparent var(--tw-gradient-from-position);--tw-gradient-to: rgb(0 0 0 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.via-\[\#0a0a0a\]{--tw-gradient-to: rgb(10 10 10 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), #0a0a0a var(--tw-gradient-via-position), var(--tw-gradient-to)}.via-white\/40{--tw-gradient-to: rgb(255 255 255 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), rgb(255 255 255 / .4) var(--tw-gradient-via-position), var(--tw-gradient-to)}.to-transparent{--tw-gradient-to: transparent var(--tw-gradient-to-position)}.p-1{padding:.25rem}.p-3{padding:.75rem}.p-6{padding:1.5rem}.px-1{padding-left:.25rem;padding-right:.25rem}.px-1\.5{padding-left:.375rem;padding-right:.375rem}.px-2{padding-left:.5rem;padding-right:.5rem}.px-3{padding-left:.75rem;padding-right:.75rem}.px-4{padding-left:1rem;padding-right:1rem}.px-6{padding-left:1.5rem;padding-right:1.5rem}.py-0\.5{padding-top:.125rem;padding-bottom:.125rem}.py-1{padding-top:.25rem;padding-bottom:.25rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.py-3{padding-top:.75rem;padding-bottom:.75rem}.pb-1{padding-bottom:.25rem}.pb-2{padding-bottom:.5rem}.pb-6{padding-bottom:1.5rem}.pr-1{padding-right:.25rem}.pt-2{padding-top:.5rem}.text-center{text-align:center}.text-right{text-align:right}.font-body{font-family:Noto Sans SC,Noto Sans JP,sans-serif}.font-display{font-family:Teko,Oswald,sans-serif}.font-serif{font-family:ui-serif,Georgia,Cambria,Times New Roman,Times,serif}.text-2xl{font-size:1.5rem;line-height:2rem}.text-3xl{font-size:1.875rem;line-height:2.25rem}.text-4xl{font-size:2.25rem;line-height:2.5rem}.text-\[10px\]{font-size:10px}.text-\[11px\]{font-size:11px}.text-\[14px\]{font-size:14px}.text-\[8px\]{font-size:8px}.text-\[9px\]{font-size:9px}.text-base{font-size:1rem;line-height:1.5rem}.text-lg{font-size:1.125rem;line-height:1.75rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xl{font-size:1.25rem;line-height:1.75rem}.text-xs{font-size:.75rem;line-height:1rem}.font-black{font-weight:900}.font-bold{font-weight:700}.font-semibold{font-weight:600}.uppercase{text-transform:uppercase}.italic{font-style:italic}.tabular-nums{--tw-numeric-spacing: tabular-nums;font-variant-numeric:var(--tw-ordinal) var(--tw-slashed-zero) var(--tw-numeric-figure) var(--tw-numeric-spacing) var(--tw-numeric-fraction)}.leading-none{line-height:1}.tracking-\[0\.5em\]{letter-spacing:.5em}.tracking-tight{letter-spacing:-.025em}.tracking-tighter{letter-spacing:-.05em}.tracking-wide{letter-spacing:.025em}.tracking-wider{letter-spacing:.05em}.tracking-widest{letter-spacing:.1em}.text-black{--tw-text-opacity: 1;color:rgb(0 0 0 / var(--tw-text-opacity, 1))}.text-black\/50{color:#00000080}.text-black\/60{color:#0009}.text-crimson-600{--tw-text-opacity: 1;color:rgb(217 0 24 / var(--tw-text-opacity, 1))}.text-gray-300{--tw-text-opacity: 1;color:rgb(209 213 219 / var(--tw-text-opacity, 1))}.text-gray-400{--tw-text-opacity: 1;color:rgb(156 163 175 / var(--tw-text-opacity, 1))}.text-gray-500{--tw-text-opacity: 1;color:rgb(107 114 128 / var(--tw-text-opacity, 1))}.text-white{--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity, 1))}.text-white\/70{color:#ffffffb3}.text-white\/80{color:#fffc}.text-yellow-400{--tw-text-opacity: 1;color:rgb(250 204 21 / var(--tw-text-opacity, 1))}.opacity-0{opacity:0}.opacity-10{opacity:.1}.opacity-100{opacity:1}.opacity-20{opacity:.2}.opacity-25{opacity:.25}.opacity-35{opacity:.35}.opacity-40{opacity:.4}.opacity-5{opacity:.05}.opacity-50{opacity:.5}.opacity-60{opacity:.6}.opacity-70{opacity:.7}.opacity-90{opacity:.9}.opacity-\[0\.03\]{opacity:.03}.mix-blend-multiply{mix-blend-mode:multiply}.mix-blend-overlay{mix-blend-mode:overlay}.shadow-\[0_0_0_2px_black\]{--tw-shadow: 0 0 0 2px black;--tw-shadow-colored: 0 0 0 2px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-\[0_0_10px_\#d90018\]{--tw-shadow: 0 0 10px #d90018;--tw-shadow-colored: 0 0 10px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-\[0_0_16px_rgba\(217\,0\,24\,0\.65\)\]{--tw-shadow: 0 0 16px rgba(217,0,24,.65);--tw-shadow-colored: 0 0 16px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-\[10px_10px_0_\#d90018\]{--tw-shadow: 10px 10px 0 #d90018;--tw-shadow-colored: 10px 10px 0 var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-\[2px_2px_0_black\]{--tw-shadow: 2px 2px 0 black;--tw-shadow-colored: 2px 2px 0 var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-\[4px_4px_0_\#d90018\]{--tw-shadow: 4px 4px 0 #d90018;--tw-shadow-colored: 4px 4px 0 var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-\[4px_4px_0px_\#000\]{--tw-shadow: 4px 4px 0px #000;--tw-shadow-colored: 4px 4px 0px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-\[6px_6px_0_0_black\]{--tw-shadow: 6px 6px 0 0 black;--tw-shadow-colored: 6px 6px 0 0 var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-\[8px_8px_0_\#d90018\]{--tw-shadow: 8px 8px 0 #d90018;--tw-shadow-colored: 8px 8px 0 var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-\[8px_8px_0px_\#d90018\]{--tw-shadow: 8px 8px 0px #d90018;--tw-shadow-colored: 8px 8px 0px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-lg{--tw-shadow: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--tw-shadow-colored: 0 10px 15px -3px var(--tw-shadow-color), 0 4px 6px -4px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-md{--tw-shadow: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--tw-shadow-colored: 0 4px 6px -1px var(--tw-shadow-color), 0 2px 4px -2px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.ring-2{--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000)}.ring-crimson-500{--tw-ring-opacity: 1;--tw-ring-color: rgb(255 0 30 / var(--tw-ring-opacity, 1))}.blur{--tw-blur: blur(8px);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)}.drop-shadow-\[3px_3px_0_\#d90018\]{--tw-drop-shadow: drop-shadow(3px 3px 0 #d90018);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)}.drop-shadow-md{--tw-drop-shadow: drop-shadow(0 4px 3px rgb(0 0 0 / .07)) drop-shadow(0 2px 2px rgb(0 0 0 / .06));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)}.drop-shadow-sm{--tw-drop-shadow: drop-shadow(0 1px 1px rgb(0 0 0 / .05));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)}.grayscale{--tw-grayscale: grayscale(100%);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)}.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,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter!important;transition-timing-function:cubic-bezier(.4,0,.2,1)!important;transition-duration:.15s!important}.transition{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-all{transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-colors{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-opacity{transition-property:opacity;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-transform{transition-property:transform;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.duration-150{transition-duration:.15s}.duration-200{transition-duration:.2s}.duration-300{transition-duration:.3s}.duration-700{transition-duration:.7s}.ease-out{transition-timing-function:cubic-bezier(0,0,.2,1)}.animate-scan{animation:scan 2s linear infinite}:root{--safe-area-top: env(safe-area-inset-top, 0px);--safe-area-right: env(safe-area-inset-right, 0px);--safe-area-bottom: env(safe-area-inset-bottom, 0px);--safe-area-left: env(safe-area-inset-left, 0px);--ui-bg: #0b0b0d;--ui-panel: #141416;--ui-panel-strong: #101114;--ui-text: #f8fafc;--ui-muted: rgba(248, 250, 252, .65);--ui-muted-2: rgba(248, 250, 252, .45);--ui-accent: #d90018;--ui-accent-2: #f2c94c;--ui-danger: #f87171;--ui-border: rgba(255, 255, 255, .12);--ui-border-soft: rgba(255, 255, 255, .08);--ui-border-strong: rgba(217, 0, 24, .9);--ui-shadow: 0 18px 32px rgba(0, 0, 0, .55);--ui-shadow-strong: 0 24px 40px rgba(0, 0, 0, .7);--ui-glow: 0 0 14px rgba(217, 0, 24, .4);--ui-glow-strong: 0 0 20px rgba(248, 113, 113, .55);--ui-cut: 12px;--ui-cut-btn: 8px;--ui-font-sans: "Noto Sans SC", "Noto Sans JP", sans-serif;--ui-font-display: "Teko", "Oswald", sans-serif;--ui-space-1: 4px;--ui-space-2: 8px;--ui-space-3: 12px;--ui-space-4: 16px;--ui-space-5: 20px;--ui-space-6: 24px;--ui-duration-fast: .12s;--ui-duration: .2s;--ui-duration-slow: .32s;--ui-ease: cubic-bezier(.2, .8, .2, 1);--ui-panel-grad-a: rgba(20, 20, 22, .95);--ui-panel-grad-b: rgba(8, 8, 10, .9);--ui-panel-grad-c: rgba(255, 255, 255, .06);--ui-panel-hero-a: rgba(28, 12, 16, .95);--ui-panel-hero-b: rgba(8, 6, 8, .92);--ui-panel-hero-c: rgba(217, 0, 24, .12);--ui-modal-padding: 20px;--ui-titlebar-h: 44px;--ui-progress-height: 4px;--ui-panel-bg-texture: none;--ui-panel-corner-asset: none;--ui-title-icon: none;--ui-titlebar-bg: #0b0b0d;--ui-titlebar-accent: #d90018;--ui-sticker-bg: #d90018;--ui-sticker-text: #ffffff;--ui-sticker-bg-2: #f2c94c;--ui-sticker-text-2: #0b0b0d;--ui-sticker-bg-mono: var(--ui-panel-strong);--ui-sticker-text-mono: var(--ui-text);--ui-backdrop-accent: rgba(217, 0, 24, .18);--ui-backdrop-1: rgba(0, 0, 0, .55);--ui-backdrop-2: rgba(0, 0, 0, .8);--ui-transparent: rgba(0, 0, 0, 0);--ui-progress-track: rgba(255, 255, 255, .12);--ui-progress-fill: rgba(217, 0, 24, .85);--ui-progress-critical: rgba(248, 113, 113, .95);--ui-progress-glow: 0 0 12px rgba(217, 0, 24, .5);--ui-progress-glow-critical: 0 0 14px rgba(248, 113, 113, .6);--ui-accent-strip: rgba(217, 0, 24, .7);--ui-backdrop: radial-gradient( circle at 30% 20%, var(--ui-backdrop-accent), var(--ui-transparent) 45% ), linear-gradient(180deg, var(--ui-backdrop-1), var(--ui-backdrop-2));color-scheme:dark;background-color:var(--ui-bg)}[data-theme=p5]{--ui-bg: #0b0b0d;--ui-panel: #141416;--ui-panel-strong: #101114;--ui-text: #f8fafc;--ui-muted: rgba(248, 250, 252, .65);--ui-muted-2: rgba(248, 250, 252, .45);--ui-accent: #d90018;--ui-accent-2: #f2c94c;--ui-danger: #f87171;--ui-border: rgba(255, 255, 255, .12);--ui-border-soft: rgba(255, 255, 255, .08);--ui-border-strong: rgba(217, 0, 24, .9);--ui-shadow: 0 18px 32px rgba(0, 0, 0, .55);--ui-shadow-strong: 0 24px 40px rgba(0, 0, 0, .7);--ui-glow: 0 0 14px rgba(217, 0, 24, .4);--ui-glow-strong: 0 0 20px rgba(248, 113, 113, .55);--ui-panel-grad-a: rgba(20, 20, 22, .95);--ui-panel-grad-b: rgba(8, 8, 10, .9);--ui-panel-grad-c: rgba(255, 255, 255, .06);--ui-panel-hero-a: rgba(28, 12, 16, .95);--ui-panel-hero-b: rgba(8, 6, 8, .92);--ui-panel-hero-c: rgba(217, 0, 24, .12);--ui-backdrop-accent: rgba(217, 0, 24, .18);--ui-backdrop-1: rgba(0, 0, 0, .55);--ui-backdrop-2: rgba(0, 0, 0, .8);--ui-progress-track: rgba(255, 255, 255, .12);--ui-progress-fill: rgba(217, 0, 24, .85);--ui-progress-critical: rgba(248, 113, 113, .95);--ui-progress-glow: 0 0 12px rgba(217, 0, 24, .5);--ui-progress-glow-critical: 0 0 14px rgba(248, 113, 113, .6);--ui-accent-strip: rgba(217, 0, 24, .7)}[data-theme=festival]{--ui-bg: #fffdf5;--ui-panel: rgba(255, 255, 255, .92);--ui-panel-strong: #ffffff;--ui-text: #2c3e50;--ui-muted: rgba(44, 62, 80, .55);--ui-muted-2: rgba(44, 62, 80, .4);--ui-accent: #ff4081;--ui-accent-2: #5c6bc0;--ui-danger: #e57373;--ui-border: rgba(92, 107, 192, .25);--ui-border-soft: rgba(92, 107, 192, .18);--ui-border-strong: rgba(255, 64, 129, .55);--ui-shadow: 0 12px 24px rgba(60, 60, 90, .18);--ui-shadow-strong: 0 18px 32px rgba(60, 60, 90, .22);--ui-glow: 0 0 0 rgba(0, 0, 0, 0);--ui-glow-strong: 0 0 0 rgba(0, 0, 0, 0);--ui-cut: 0px;--ui-cut-btn: 0px;--ui-font-display: "Noto Sans JP", "Noto Sans SC", sans-serif;--ui-panel-grad-a: rgba(255, 255, 255, .96);--ui-panel-grad-b: rgba(248, 250, 252, .92);--ui-panel-grad-c: rgba(255, 255, 255, .65);--ui-panel-hero-a: rgba(255, 255, 255, .98);--ui-panel-hero-b: rgba(248, 250, 252, .95);--ui-panel-hero-c: rgba(255, 64, 129, .08);--ui-backdrop-accent: rgba(255, 192, 203, .2);--ui-backdrop-1: rgba(255, 253, 245, .6);--ui-backdrop-2: rgba(255, 236, 245, .9);--ui-progress-track: rgba(92, 107, 192, .18);--ui-progress-fill: #ff4081;--ui-progress-critical: #e91e63;--ui-progress-glow: 0 0 0 rgba(0, 0, 0, 0);--ui-progress-glow-critical: 0 0 0 rgba(0, 0, 0, 0);--ui-accent-strip: rgba(255, 64, 129, .25);--ui-panel-bg-texture: none;--ui-panel-corner-asset: none;--ui-title-icon: none;--ui-titlebar-bg: var(--ui-panel-strong);--ui-titlebar-accent: var(--ui-accent);--ui-sticker-bg: var(--ui-accent);--ui-sticker-text: var(--ui-panel-strong);--ui-sticker-bg-2: var(--ui-accent-2);--ui-sticker-text-2: var(--ui-panel-strong);--ui-sticker-bg-mono: var(--ui-panel-strong);--ui-sticker-text-mono: var(--ui-text);--ui-radius: 18px;--ui-radius-lg: 24px;--ui-radius-sm: 12px;--ui-card-face: #ffffff;--ui-card-border: rgba(92, 107, 192, .25);--ui-card-shadow: 0 8px 16px rgba(60, 60, 90, .16);--ui-card-shadow-selected: 0 12px 22px rgba(255, 64, 129, .28);--ui-card-back: #5c6bc0;--ui-card-back-2: #3949ab;--ui-card-back-border: rgba(255, 255, 255, .4);--ui-card-back-line: rgba(255, 255, 255, .25);--ui-card-back-glow: rgba(255, 255, 255, .2);--ui-card-back-sheen: rgba(255, 255, 255, .12);--ui-card-gloss: rgba(255, 255, 255, .7);--ui-card-red: #e91e63;--ui-card-black: #2c3e50;--ui-rank-top-bg: rgba(255, 235, 130, .85);--ui-rank-top-border: rgba(240, 194, 60, .7);--ui-rank-top-text: #805b00;--ui-rank-dead-bg: rgba(60, 60, 70, .9);--ui-rank-dead-border: rgba(60, 60, 70, .9);--ui-rank-dead-text: #f5f5f5;--ui-btn-primary-bg: linear-gradient(90deg, #ff4081, #ff80ab);--ui-btn-secondary-bg: #ffffff;--ui-btn-secondary-text: #5c6bc0;--ui-btn-secondary-border: rgba(92, 107, 192, .6);--ui-hud-pill: rgba(255, 255, 255, .85);--ui-hud-pill-border: rgba(255, 192, 203, .4);--ui-hud-pill-text: #3b4455;--ui-hud-pill-accent: rgba(255, 128, 171, .35);--ui-petal: rgba(255, 160, 180, .65);--ui-sky-a: #e0f7fa;--ui-sky-b: #fffdf5;--ui-pattern: rgba(92, 107, 192, .18);--ui-mist: rgba(252, 228, 236, .6);color-scheme:light}[data-theme=classic]{--ui-bg: #0f5e34;--ui-panel: #ffffff;--ui-panel-strong: #ffffff;--ui-text: #111111;--ui-muted: rgba(17, 17, 17, .6);--ui-muted-2: rgba(17, 17, 17, .4);--ui-accent: #dc2626;--ui-accent-2: #fbbf24;--ui-danger: #ef4444;--ui-border: rgba(17, 17, 17, .22);--ui-border-soft: rgba(17, 17, 17, .14);--ui-border-strong: #111111;--ui-shadow: 0 14px 24px rgba(0, 0, 0, .35);--ui-shadow-strong: 0 18px 32px rgba(0, 0, 0, .45);--ui-glow: 0 0 0 rgba(0, 0, 0, 0);--ui-glow-strong: 0 0 0 rgba(0, 0, 0, 0);--ui-cut: 0px;--ui-cut-btn: 0px;--ui-font-display: "Oswald", "Teko", sans-serif;--ui-panel-grad-a: #ffffff;--ui-panel-grad-b: #f5f5f5;--ui-panel-grad-c: #ffffff;--ui-panel-hero-a: #ffffff;--ui-panel-hero-b: #f3f3f3;--ui-panel-hero-c: rgba(217, 0, 24, .08);--ui-backdrop-accent: rgba(0, 0, 0, .22);--ui-backdrop-1: rgba(0, 0, 0, .55);--ui-backdrop-2: rgba(0, 0, 0, .75);--ui-progress-track: rgba(0, 0, 0, .14);--ui-progress-fill: #dc2626;--ui-progress-critical: #ef4444;--ui-progress-glow: 0 0 0 rgba(0, 0, 0, 0);--ui-progress-glow-critical: 0 0 0 rgba(0, 0, 0, 0);--ui-accent-strip: #dc2626;--ui-titlebar-bg: #ffffff;--ui-titlebar-accent: #fbbf24;--ui-sticker-bg: #dc2626;--ui-sticker-text: #ffffff;--ui-sticker-bg-2: #fbbf24;--ui-sticker-text-2: #111111;--ui-sticker-bg-mono: #ffffff;--ui-sticker-text-mono: #111111;--ui-radius: 16px;--ui-radius-lg: 20px;--ui-radius-sm: 12px;--ui-card-face: #ffffff;--ui-card-border: #cbd5e1;--ui-card-shadow: 0 10px 18px rgba(0, 0, 0, .25);--ui-card-shadow-selected: 0 14px 22px rgba(30, 64, 175, .3);--ui-card-back: #1d4ed8;--ui-card-back-2: #1e3a8a;--ui-card-red: #dc2626;--ui-card-black: #111111;--classic-felt-a: #1a7f4a;--classic-felt-b: #0f5e34;--classic-felt-c: #0a3f23;--classic-felt-vignette: rgba(0, 0, 0, .6);--classic-btn-play: #2563eb;--classic-btn-pass: #dc2626;--classic-btn-hint: #6b7280;--classic-event-red: #ef4444;--classic-event-blue: #3b82f6;--classic-event-gold: #fbbf24;--classic-event-slate: #94a3b8;--classic-event-purple: #a855f7;--classic-event-mono: #f8fafc;color-scheme:dark}*,*:before,*:after{box-sizing:border-box}html,body,#app,#overlay{width:100%;height:100%;margin:0}body{overflow:hidden;background:var(--ui-bg);font-family:var(--ui-font-sans)}#app{position:relative}#overlay{position:fixed;inset:0;z-index:10;pointer-events:none}@keyframes scan{0%{top:-15%}to{top:115%}}@keyframes notice-pop{0%{transform:translate(-50%,-50%) scale(.96);opacity:0}to{transform:translate(-50%,-50%) scale(1);opacity:1}}.ui-backdrop{position:fixed;inset:0;background:var(--ui-backdrop);z-index:40;pointer-events:none}.ui-modal{position:absolute;transform:translate(-50%,-50%);pointer-events:auto;max-width:var(--ui-modal-max-w, none)}.ui-panel{--ui-panel-cut: var(--ui-cut);--ui-panel-clip: polygon( 0 0, calc(100% - var(--ui-panel-cut)) 0, 100% var(--ui-panel-cut), 100% 100%, var(--ui-panel-cut) 100%, 0 calc(100% - var(--ui-panel-cut)) );position:relative;color:var(--ui-text);background-image:var(--ui-panel-bg-texture),linear-gradient(135deg,var(--ui-panel-grad-a),var(--ui-panel-grad-b) 55%,var(--ui-panel-grad-c) 85%);border:2px solid var(--ui-border-strong);box-shadow:var(--ui-shadow);clip-path:var(--ui-panel-clip)}.ui-panel:before{content:"";position:absolute;inset:4px;border:1px solid var(--ui-border);clip-path:var(--ui-panel-clip);pointer-events:none}.ui-panel:after{content:"";position:absolute;left:0;top:0;width:10px;height:100%;background:var(--ui-accent-strip);pointer-events:none}.ui-panel__content{padding:var(--ui-modal-padding)}.ui-panel--flat{box-shadow:none;border-width:1px;border-color:var(--ui-border);background-image:var(--ui-panel-bg-texture),linear-gradient(180deg,var(--ui-panel-grad-a),var(--ui-panel-grad-b) 60%,var(--ui-panel-grad-c) 95%)}.ui-panel--flat:before{border-color:var(--ui-border-soft)}.ui-panel--flat:after{background:var(--ui-accent-strip);opacity:.6}.ui-panel--hero{--ui-panel-cut: calc(var(--ui-cut) + 4px);background-image:var(--ui-panel-bg-texture),linear-gradient(135deg,var(--ui-panel-hero-a),var(--ui-panel-hero-b) 55%,var(--ui-panel-hero-c) 85%);border-width:3px;box-shadow:var(--ui-shadow-strong)}.ui-panel--hero.ui-panel--flat{box-shadow:none;border-width:2px}.ui-panel--paper{--ui-text: #111111;--ui-muted: rgba(17, 17, 17, .55);--ui-muted-2: rgba(17, 17, 17, .4);--ui-border: rgba(17, 17, 17, .18);--ui-border-soft: rgba(17, 17, 17, .12);--ui-border-strong: var(--ui-accent);--ui-panel: #ffffff;--ui-panel-strong: #ffffff;--ui-panel-grad-a: #ffffff;--ui-panel-grad-b: #f6f6f6;--ui-panel-grad-c: #ffffff;--ui-panel-hero-a: #ffffff;--ui-panel-hero-b: #f5f5f5;--ui-panel-hero-c: rgba(217, 0, 24, .08);--ui-progress-track: rgba(17, 17, 17, .12);color:var(--ui-text)}.ui-panel--paper .ui-divider{background:#1113}.ui-panel--paper .ui-list-row{border-bottom-color:#1111112e}.ui-panel--flash{box-shadow:var(--ui-shadow-strong),var(--ui-glow-strong)}.ui-titlebar{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--ui-space-4);min-height:var(--ui-titlebar-h)}.ui-titlebar--slanted{align-items:center}.ui-titlebar__main{display:flex;flex-direction:column;gap:6px}.ui-titlebar__strip{--ui-strip-cut: var(--ui-cut-btn);display:inline-flex;align-items:center;justify-content:center;padding:4px 14px;background:linear-gradient(90deg,var(--ui-titlebar-bg) 0%,var(--ui-titlebar-bg) 65%,var(--ui-titlebar-accent) 65%,var(--ui-titlebar-accent) 100%);border:2px solid var(--ui-border-strong);box-shadow:var(--ui-shadow);clip-path:polygon(0 0,calc(100% - var(--ui-strip-cut)) 0,100% var(--ui-strip-cut),100% 100%,var(--ui-strip-cut) 100%,0 calc(100% - var(--ui-strip-cut)));transform:skew(-10deg)}.ui-titlebar__title{display:block;transform:skew(10deg)}.ui-titlebar__subtitle{font-size:12px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--ui-text)}.ui-titlebar__aside{display:flex;flex-direction:column;align-items:flex-end;gap:6px}.ui-title{color:var(--ui-text);font-family:var(--ui-font-display);font-style:italic;font-weight:800;text-transform:uppercase;letter-spacing:.24em}.ui-kicker{color:var(--ui-accent-2);font-family:var(--ui-font-display);text-transform:uppercase;letter-spacing:.4em}.ui-divider{height:1px;background:var(--ui-border)}.ui-text{color:var(--ui-text)}.ui-text--muted{color:var(--ui-muted)}.ui-text--subtle{color:var(--ui-muted-2)}.ui-text--accent{color:var(--ui-accent)}.ui-text--accent-2{color:var(--ui-accent-2)}.ui-text--critical{color:var(--ui-danger)}.ui-btn{--ui-btn-cut: var(--ui-cut-btn);position:relative;display:inline-flex;align-items:center;justify-content:center;min-height:44px;padding:0 var(--ui-space-5);border:2px solid var(--ui-border);background:var(--ui-panel);color:var(--ui-text);font-family:var(--ui-font-display);text-transform:uppercase;letter-spacing:.18em;clip-path:polygon(0 0,calc(100% - var(--ui-btn-cut)) 0,100% var(--ui-btn-cut),100% 100%,var(--ui-btn-cut) 100%,0 calc(100% - var(--ui-btn-cut)));transform:skew(-10deg);box-shadow:var(--ui-shadow);transition:transform var(--ui-duration-fast) var(--ui-ease),box-shadow var(--ui-duration-fast) var(--ui-ease),border-color var(--ui-duration-fast) var(--ui-ease)}.ui-btn__label{transform:skew(10deg);font-size:16px;font-weight:800}.ui-btn--flat{box-shadow:none;border-width:1px;border-color:var(--ui-border);background:var(--ui-panel-strong)}.ui-btn--flat.ui-btn--primary{border-color:var(--ui-border-strong);box-shadow:none}.ui-btn--flat:hover:not(:disabled){box-shadow:none;transform:skew(-10deg) translateY(-1px)}.ui-btn--primary{border-color:var(--ui-accent);box-shadow:var(--ui-shadow),var(--ui-glow)}.ui-btn--secondary{border-color:var(--ui-border);color:var(--ui-text)}.ui-btn--sm{min-height:32px;padding:0 var(--ui-space-3);letter-spacing:.14em}.ui-btn--sm .ui-btn__label{font-size:11px;font-weight:700}.ui-btn:hover:not(:disabled){box-shadow:var(--ui-shadow),var(--ui-glow);transform:skew(-10deg) translateY(-1px)}.ui-btn:active:not(:disabled){box-shadow:var(--ui-shadow);transform:skew(-10deg) translateY(1px)}.ui-btn:disabled{border-color:var(--ui-border-soft);color:var(--ui-muted);box-shadow:none;cursor:not-allowed}.ui-progress{position:relative;width:100%;height:var(--ui-progress-height, 4px);background:var(--ui-progress-track);border:1px solid var(--ui-border-soft);box-shadow:inset 0 0 0 1px var(--ui-transparent);overflow:hidden;clip-path:polygon(0 0,calc(100% - var(--ui-cut-btn)) 0,100% var(--ui-cut-btn),100% 100%,var(--ui-cut-btn) 100%,0 calc(100% - var(--ui-cut-btn)))}.ui-progress--thick{height:var(--ui-progress-height, 4px)}.ui-progress--thin{height:calc(var(--ui-progress-height, 4px) - 1px)}.ui-progress__bar{height:100%;width:0%;background:var(--ui-progress-fill);box-shadow:var(--ui-progress-glow);transition:width var(--ui-duration-fast) linear}.ui-progress--critical{--ui-progress-fill: var(--ui-progress-critical);--ui-progress-glow: var(--ui-progress-glow-critical)}.ui-progress--flash{--ui-progress-fill: var(--ui-text);--ui-progress-glow: var(--ui-transparent)}.ui-pill{display:inline-flex;align-items:center;justify-content:center;padding:2px 8px;border:1px solid var(--ui-border);background:var(--ui-panel);color:var(--ui-text);font-size:10px;letter-spacing:.2em;text-transform:uppercase}.ui-pill--accent{border-color:var(--ui-accent);color:var(--ui-accent)}.ui-pill--muted{border-color:var(--ui-border-soft);color:var(--ui-muted);background:var(--ui-transparent)}.ui-sticker{--ui-sticker-cut: var(--ui-cut-btn);display:inline-flex;align-items:center;justify-content:center;padding:4px 10px;border:2px solid var(--ui-border-strong);background:var(--ui-sticker-bg);color:var(--ui-sticker-text);font-family:var(--ui-font-display);text-transform:uppercase;letter-spacing:.2em;box-shadow:var(--ui-shadow);clip-path:polygon(0 0,calc(100% - var(--ui-sticker-cut)) 0,100% var(--ui-sticker-cut),100% 100%,var(--ui-sticker-cut) 100%,0 calc(100% - var(--ui-sticker-cut)));transform:skew(-10deg)}.ui-sticker__text{font-size:12px;font-weight:800;font-style:italic;transform:skew(10deg)}.ui-sticker--sm{padding:2px 6px;letter-spacing:.16em}.ui-sticker--sm .ui-sticker__text{font-size:10px}.ui-sticker--accent{border-color:var(--ui-accent);background:var(--ui-sticker-bg);color:var(--ui-sticker-text)}.ui-sticker--gold{border-color:var(--ui-accent-2);background:var(--ui-sticker-bg-2);color:var(--ui-sticker-text-2)}.ui-sticker--mono{border-color:var(--ui-border);background:var(--ui-sticker-bg-mono);color:var(--ui-sticker-text-mono)}.ui-sticker--info{border-color:var(--classic-event-blue, var(--ui-accent-2));background:var(--classic-event-blue, var(--ui-accent-2));color:#fff}.ui-sticker--muted{border-color:var(--ui-border-soft);background:var(--ui-panel);color:var(--ui-muted)}.ui-toast{--ui-toast-cut: var(--ui-cut-btn);position:relative;display:inline-flex;align-items:center;gap:10px;padding:10px 16px;border:2px solid var(--ui-border-strong);background:var(--ui-panel);color:var(--ui-text);font-family:var(--ui-font-display);letter-spacing:.22em;text-transform:uppercase;box-shadow:var(--ui-shadow);overflow:hidden;clip-path:polygon(0 0,calc(100% - var(--ui-toast-cut)) 0,100% var(--ui-toast-cut),100% 100%,var(--ui-toast-cut) 100%,0 calc(100% - var(--ui-toast-cut)))}.ui-toast:before{content:"";position:absolute;inset:3px;border:1px solid var(--ui-border);clip-path:polygon(0 0,calc(100% - var(--ui-toast-cut)) 0,100% var(--ui-toast-cut),100% 100%,var(--ui-toast-cut) 100%,0 calc(100% - var(--ui-toast-cut)));pointer-events:none}.ui-toast:after{content:"";position:absolute;left:0;top:0;width:8px;height:100%;background:var(--ui-accent-strip);pointer-events:none}.ui-toast>*{position:relative;z-index:1}.ui-toast--flat{box-shadow:none;border-width:1px;background:var(--ui-panel-strong)}.ui-tag{background:var(--ui-panel);color:var(--ui-text);border:1px solid var(--ui-border);box-shadow:var(--ui-shadow)}.ui-tag--flat{box-shadow:none;background:var(--ui-panel-strong)}.ui-tag--accent{border-left:4px solid var(--ui-accent)}.ui-list-row{border-bottom:1px solid var(--ui-border)}.ui-timer{display:flex;flex-direction:column;gap:var(--ui-space-2);padding:var(--ui-space-3);border:1px solid var(--ui-border);background:var(--ui-panel);box-shadow:var(--ui-shadow)}[data-theme=festival] .ui-panel,[data-theme=festival] .ui-modal,[data-theme=festival] .ui-progress,[data-theme=festival] .ui-toast,[data-theme=festival] .ui-tag,[data-theme=festival] .ui-btn{clip-path:none;border-radius:var(--ui-radius)}[data-theme=festival] .ui-panel:before{clip-path:none;border-radius:calc(var(--ui-radius) - 2px)}[data-theme=classic] .ui-panel,[data-theme=classic] .ui-modal,[data-theme=classic] .ui-progress,[data-theme=classic] .ui-toast,[data-theme=classic] .ui-tag,[data-theme=classic] .ui-btn{clip-path:none;border-radius:var(--ui-radius)}[data-theme=classic] .ui-panel:before{clip-path:none;border-radius:calc(var(--ui-radius) - 2px)}[data-theme=classic] .ui-panel:after{display:none}[data-theme=classic] .ui-titlebar__strip,[data-theme=classic] .ui-sticker{transform:none;clip-path:none;border-radius:999px;font-family:var(--ui-font-sans);letter-spacing:.12em}[data-theme=classic] .ui-titlebar__strip{border-color:var(--ui-border-strong);background:linear-gradient(90deg,var(--ui-titlebar-bg) 0%,var(--ui-titlebar-bg) 72%,var(--ui-titlebar-accent) 72%,var(--ui-titlebar-accent) 100%)}[data-theme=classic] .ui-titlebar__title,[data-theme=classic] .ui-sticker__text{transform:none;font-style:normal}[data-theme=classic] .ui-title{font-style:normal;font-weight:800}[data-theme=classic] .ui-toast:before,[data-theme=classic] .ui-toast:after{display:none}[data-theme=festival] .ui-titlebar__strip,[data-theme=festival] .ui-sticker{transform:none;clip-path:none;border-radius:var(--ui-radius-sm);font-family:var(--ui-font-sans);letter-spacing:.1em}[data-theme=festival] .ui-titlebar__strip{border-color:var(--ui-border);background:var(--ui-panel-strong)}[data-theme=festival] .ui-titlebar__title,[data-theme=festival] .ui-sticker__text{transform:none;font-style:normal}[data-theme=festival] .ui-title{font-style:normal;font-weight:700}[data-theme=festival] .ui-toast:before{clip-path:none;border-radius:calc(var(--ui-radius) - 4px)}[data-theme=festival] .ui-toast:after{opacity:.2}[data-theme=festival] .ui-panel{border-width:1px;border-color:var(--ui-border);box-shadow:var(--ui-shadow)}[data-theme=classic] .ui-panel{border-width:2px;border-color:var(--ui-border-strong);box-shadow:var(--ui-shadow)}[data-theme=festival] .ui-btn{transform:none;font-family:var(--ui-font-sans);letter-spacing:.08em;text-transform:none;background:var(--ui-btn-secondary-bg);border-color:var(--ui-btn-secondary-border);color:var(--ui-btn-secondary-text);box-shadow:var(--ui-shadow)}[data-theme=festival] .ui-btn__label{transform:none;font-weight:700}[data-theme=classic] .ui-btn{transform:none;font-family:var(--ui-font-sans);letter-spacing:.08em;text-transform:uppercase;border-radius:999px;border-color:var(--ui-border-strong);box-shadow:var(--ui-shadow)}[data-theme=classic] .ui-btn__label{transform:none;font-weight:800}[data-theme=festival] .ui-btn--primary{background:var(--ui-btn-primary-bg);color:var(--ui-panel-strong);border-color:transparent}[data-theme=festival] .ui-btn--secondary{background:var(--ui-btn-secondary-bg);color:var(--ui-btn-secondary-text);border-color:var(--ui-btn-secondary-border)}[data-theme=classic] .ui-btn--primary{background:#111;color:#fff;border-color:#111}[data-theme=classic] .ui-btn--secondary{background:#f3f4f6;color:#111;border-color:#d1d5db}[data-theme=festival] .ui-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:var(--ui-shadow-strong)}[data-theme=festival] .ui-btn:active:not(:disabled){transform:translateY(1px);box-shadow:var(--ui-shadow)}[data-theme=classic] .ui-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:var(--ui-shadow-strong)}[data-theme=classic] .ui-btn:active:not(:disabled){transform:translateY(1px);box-shadow:var(--ui-shadow)}[data-theme=festival] .ui-progress{border-radius:var(--ui-radius-sm);border-color:var(--ui-border-soft)}[data-theme=classic] .ui-progress{border-radius:999px;border-color:var(--ui-border-soft)}[data-theme=festival] .ui-progress__bar{border-radius:var(--ui-radius-sm)}[data-theme=classic] .ui-progress__bar{border-radius:999px}[data-theme=festival] .ui-toast,[data-theme=festival] .toast-base{border-radius:var(--ui-radius-lg);border-color:var(--ui-border);background:var(--ui-panel);box-shadow:var(--ui-shadow);font-family:var(--ui-font-sans);letter-spacing:.14em}[data-theme=classic] .ui-toast,[data-theme=classic] .toast-base{border-radius:999px;border-color:currentColor;background:#000000bf;box-shadow:var(--ui-shadow-strong);font-family:var(--ui-font-sans);letter-spacing:.18em}[data-theme=festival] .toast-text{font-style:normal}.event-toast{--toast-duration: 1s;--toast-color: #d8d8d8;color:var(--toast-color)}.event-toast--p5{color:var(--toast-color)}.p5-toast{--p5-toast-color: var(--toast-color);position:relative;display:inline-flex;align-items:center;justify-content:center;padding:10px 18px;border:2px solid #ffffff;background:#000;box-shadow:0 0 20px #d9001880;transform:skew(-20deg);animation:p5-toast var(--toast-duration, 1s) ease-out both}.p5-toast--flip{animation:p5-toast var(--toast-duration, 1s) ease-out both,p5-toast-flip var(--toast-duration, 1s) ease-out both;transform-origin:center top}.p5-toast__inner{display:inline-flex;align-items:center;gap:10px;transform:skew(20deg)}.p5-toast__icon{display:inline-flex;align-items:center;justify-content:center;color:var(--p5-toast-color)}.p5-toast__text{display:flex;flex-direction:column;align-items:flex-start;gap:2px}.p5-toast__title{color:var(--p5-toast-color);font-size:18px;font-weight:900;font-style:italic;letter-spacing:.26em;text-transform:uppercase;white-space:nowrap}.p5-toast__subtitle{color:#fff;font-size:11px;font-weight:700;letter-spacing:.24em;text-transform:uppercase;white-space:nowrap}.p5-toast__fx{position:absolute;inset:0;pointer-events:none;color:var(--p5-toast-color)}.p5-toast__fx--cut:before,.p5-toast__fx--cut:after{content:"";position:absolute;left:8%;right:8%;height:2px;background:var(--p5-toast-color);opacity:0;animation:p5-toast-cut var(--toast-duration, 1s) ease-out both}.p5-toast__fx--cut:before{top:45%}.p5-toast__fx--cut:after{top:55%;opacity:.6}.p5-toast__fx--stamp{position:absolute;top:-10px;right:14px;padding:2px 6px;border:2px solid var(--p5-toast-color);background:#000;color:var(--p5-toast-color);font-size:9px;font-weight:900;letter-spacing:.2em;text-transform:uppercase;transform:skew(-20deg);opacity:0;animation:p5-toast-stamp var(--toast-duration, 1s) ease-out both}.p5-toast__fx--swap{position:absolute;right:16px;top:50%;transform:translateY(-50%) skew(-20deg);font-size:12px;font-weight:900;letter-spacing:.2em;opacity:0;animation:p5-toast-swap var(--toast-duration, 1s) ease-out both}.p5-toast__fx--fall,.p5-toast__fx--rise{position:absolute;left:14px;top:-8px;width:18px;height:18px;border:2px solid var(--p5-toast-color);display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:900;background:#000;transform:skew(-20deg);opacity:0}.p5-toast__fx--fall{animation:p5-toast-fall var(--toast-duration, 1s) ease-out both}.p5-toast__fx--rise{animation:p5-toast-rise var(--toast-duration, 1s) ease-out both}.pass-pill{display:inline-flex;align-items:center;justify-content:center;padding:6px 12px;font-weight:900;font-size:14px;text-transform:uppercase;letter-spacing:.16em;white-space:nowrap}.pass-pill--p5{background:#111;color:#fff;border:2px solid #ffffff;box-shadow:2px 2px #000;transform:skew(-10deg) rotate(-6deg);font-style:italic}.pass-pill--festival{background:var(--ui-panel);color:var(--ui-text);border:1px solid var(--ui-border);border-radius:999px;box-shadow:var(--ui-shadow);letter-spacing:.14em}.pass-pill--classic{background:#111;color:#fff;border:2px solid #111111;border-radius:999px;box-shadow:var(--ui-shadow);letter-spacing:.14em}.toast-base{position:relative;display:inline-flex;align-items:center;justify-content:center;gap:10px;padding:10px 16px;border-radius:14px;border:2px solid var(--ui-border-strong);background:var(--ui-panel);box-shadow:var(--ui-shadow);color:var(--toast-color);font-family:Teko,Oswald,sans-serif;letter-spacing:.22em;text-transform:uppercase}.toast-titlebar{display:flex;flex-direction:column;align-items:center;gap:6px;text-align:center}.toast-titlebar__strip{--ui-strip-cut: var(--ui-cut-btn);padding:3px 12px;background:var(--ui-titlebar-bg)}.toast-title{color:var(--toast-color);font-size:18px;font-weight:800;font-style:italic;line-height:1;white-space:nowrap}.toast-subtitle{font-size:11px;font-weight:700;letter-spacing:.32em;text-transform:uppercase;color:var(--ui-text);white-space:nowrap}.toast-small{padding:8px 12px}.toast-generic{animation:toast-generic var(--toast-duration, 1s) ease-out both}.toast-revolution{transform-origin:center top;animation:toast-revolution var(--toast-duration, 1s) ease-out both}.toast-counter{transform-origin:center top;animation:toast-counter var(--toast-duration, 1s) ease-out both}.toast-fall{animation:toast-generic var(--toast-duration, 1s) ease-out both}.toast-crown{width:30px;height:16px;animation:toast-crown-drop var(--toast-duration, 1s) ease-out both}.toast-spade{animation:toast-generic var(--toast-duration, 1s) ease-out both}.toast-stamp{animation:toast-stamp var(--toast-duration, 1s) ease-out both}.toast-stamp--tiny{letter-spacing:.16em}.toast-joker{animation:toast-joker var(--toast-duration, 1s) ease-out both}.toast-tribute{animation:toast-tribute var(--toast-duration, 1s) ease-out both}.toast-tribute-submit .toast-stamp{animation:toast-stamp var(--toast-duration, 1s) ease-out both}.toast-exchange{display:inline-flex;gap:4px}.toast-exchange span{display:inline-block;width:18px;height:0;border-top:2px solid var(--toast-color);position:relative}.toast-exchange span:after{content:"";position:absolute;right:-2px;top:-4px;border:4px solid transparent;border-left-color:var(--toast-color)}.toast-exchange span:last-child{transform:scaleX(-1)}.toast-timeout{animation:toast-generic var(--toast-duration, 1s) ease-out both}.toast-dots{display:inline-flex;gap:4px;margin-left:6px}.toast-dots span{width:4px;height:4px;border-radius:999px;background:currentColor;opacity:0;animation:toast-dot .9s ease-in-out infinite}.toast-dots span:nth-child(2){animation-delay:.12s}.toast-dots span:nth-child(3){animation-delay:.24s}.toast-round{animation:toast-generic var(--toast-duration, 1s) ease-out both}.toast-cut{position:relative;display:inline-block}.toast-cut-base{visibility:hidden}.toast-cut-line{position:absolute;left:8px;right:8px;top:50%;height:2px;background:var(--toast-color);transform:translateY(-50%) rotate(-12deg) scaleX(0);animation:toast-cut-line var(--toast-duration, 1s) ease-out both}.toast-cut-left,.toast-cut-right{position:absolute;top:0;left:0}.toast-cut-left{clip-path:inset(0 50% 0 0);animation:toast-cut-left var(--toast-duration, 1s) ease-out both}.toast-cut-right{clip-path:inset(0 0 0 50%);animation:toast-cut-right var(--toast-duration, 1s) ease-out both}.rev-indicator{margin-left:8px;margin-top:8px;display:inline-flex;align-items:center;gap:6px;padding:2px 8px;border-radius:999px;border:1px solid var(--ui-accent-2);background:#0009;color:var(--ui-accent-2);font-size:10px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;overflow:hidden;max-height:24px;pointer-events:none;transition:opacity .18s ease,transform .18s ease,max-height .18s ease}.rev-indicator--on{opacity:1;transform:translateY(0) scale(1)}.rev-indicator--off{opacity:0;transform:translateY(-4px) scale(.98);max-height:0;margin-top:0}.rev-indicator__icon{width:14px;height:14px}.rev-indicator__text{font-size:10px;letter-spacing:.16em}.festival-bg{position:absolute;inset:0;overflow:hidden;background:var(--ui-bg);z-index:0}.festival-bg__sky{position:absolute;top:0;width:100%;height:260px;background:linear-gradient(180deg,var(--ui-sky-a),transparent);opacity:.85}.festival-bg__pattern{position:absolute;inset:0;opacity:.05;background-image:radial-gradient(circle at 100% 150%,var(--ui-pattern) 24%,transparent 25%,transparent 28%,var(--ui-pattern) 29%,var(--ui-pattern) 36%,transparent 37%,transparent 40%,var(--ui-pattern) 41%,var(--ui-pattern) 48%,transparent 49%,transparent 52%,var(--ui-pattern) 53%,var(--ui-pattern) 60%,transparent 61%,transparent 64%,var(--ui-pattern) 65%,var(--ui-pattern) 72%,transparent 73%,transparent 76%,var(--ui-pattern) 77%);background-size:100px 50px}.festival-bg__mist{position:absolute;bottom:0;width:100%;height:140px;background:linear-gradient(0deg,var(--ui-mist),transparent);opacity:.7}.festival-bg__petals{position:absolute;inset:0;pointer-events:none}.festival-petal{position:absolute;border-radius:60% 60% 60% 0;background:radial-gradient(circle at 30% 30%,var(--ui-panel-strong) 0%,var(--ui-petal) 70%);opacity:.75;animation-name:festival-fall;animation-timing-function:ease-in-out;animation-iteration-count:infinite}.classic-bg{position:absolute;inset:0;overflow:hidden;background:var(--ui-bg);z-index:0}.classic-bg__felt{position:absolute;inset:0;background:radial-gradient(circle at 50% 40%,var(--classic-felt-a),var(--classic-felt-b) 55%,var(--classic-felt-c) 100%)}.classic-bg__texture{position:absolute;inset:0;opacity:.12;background-image:radial-gradient(rgba(0,0,0,.3) 1px,transparent 1px),radial-gradient(rgba(0,0,0,.2) 1px,transparent 1px);background-position:0 0,8px 8px;background-size:16px 16px;pointer-events:none}.classic-bg__vignette{position:absolute;inset:0;background:radial-gradient(circle at center,rgba(0,0,0,0) 45%,var(--classic-felt-vignette) 100%);opacity:.85;pointer-events:none}.classic-card{position:relative;display:flex;flex-direction:column;justify-content:space-between;padding:6px;border-radius:12px;border:1px solid var(--ui-card-border);background:var(--ui-card-face);box-shadow:var(--ui-card-shadow);color:var(--ui-card-black);font-weight:700;-webkit-user-select:none;-moz-user-select:none;user-select:none;pointer-events:auto;transition:transform .15s ease,box-shadow .15s ease,border-color .15s ease}.classic-card.is-red{color:var(--ui-card-red)}.classic-card.is-selected{border-color:#2563eb;box-shadow:var(--ui-card-shadow-selected)}.classic-card.is-dimmed{opacity:.6}.classic-card__corner{display:flex;align-items:center;gap:4px;font-size:14px}.classic-card__corner--bottom{transform:rotate(180deg);align-self:flex-end}.classic-card__suit-icon{font-size:16px;line-height:1}.classic-card__suit{font-size:36px;line-height:1;text-align:center;opacity:.9}.classic-card--sm{padding:4px;border-radius:8px}.classic-card--sm .classic-card__corner{font-size:10px}.classic-card--sm .classic-card__suit{font-size:20px}.classic-card--back{border:2px solid #ffffff;background:linear-gradient(135deg,var(--ui-card-back),var(--ui-card-back-2))}.classic-card__back-inner{position:absolute;inset:6px;border-radius:8px;border:1px solid rgba(255,255,255,.5);background-image:repeating-linear-gradient(45deg,rgba(255,255,255,.15),rgba(255,255,255,.15) 6px,transparent 6px,transparent 12px)}.classic-player{display:flex;flex-direction:column;align-items:center;gap:6px;padding:8px 10px;border-radius:14px;border:1px solid rgba(255,255,255,.2);background:#00000059;color:#fff;min-width:90px;transition:transform .2s ease,box-shadow .2s ease,background .2s ease}.classic-player.is-turn{border-color:#facc15cc;background:#facc152e;box-shadow:0 0 16px #facc1559}.classic-player.is-finished{opacity:.6;filter:grayscale(1)}.classic-player__avatar{position:relative;width:56px;height:56px;border-radius:999px;border:2px solid rgba(255,255,255,.4);display:flex;align-items:center;justify-content:center;background:#0009}.classic-player__count{position:absolute;top:-6px;right:-6px;width:22px;height:22px;border-radius:999px;border:2px solid #14532d;background:#dc2626;color:#fff;font-size:10px;font-weight:800;display:flex;align-items:center;justify-content:center}.classic-player__rank{padding:2px 8px;border-radius:999px;font-size:10px;font-weight:800;background:#fff;color:#111}.classic-player__rank.is-top{background:linear-gradient(90deg,#fbbf24,#f59e0b);color:#111}.classic-player__rank.is-bottom{background:#4b5563;color:#fff}.classic-player__name{font-size:11px;font-weight:700;color:#fff}.classic-player__thinking{font-size:10px;color:#fbbf24;text-transform:uppercase;letter-spacing:.12em}.classic-hud{display:flex;flex-direction:column;gap:6px;padding:8px 12px;border-radius:12px;border:1px solid rgba(255,255,255,.2);background:#00000073;color:#fff;min-width:160px}.classic-hud__title{font-size:16px;font-weight:800;letter-spacing:.12em;color:#fbbf24}.classic-hud__meta{display:flex;gap:12px;font-size:11px;font-weight:700;color:#fffc}.classic-auto{display:inline-flex;align-items:center;gap:10px;padding:6px 10px;border-radius:999px;border:1px solid rgba(255,255,255,.2);background:#00000080;color:#fff}.classic-auto.is-on{border-color:#22c55eb3;box-shadow:0 0 12px #22c55e66}.classic-auto__text{display:flex;flex-direction:column;align-items:flex-end;gap:2px;text-align:right}.classic-auto__label{font-size:10px;font-weight:700;letter-spacing:.2em}.classic-auto__state{font-size:11px;font-weight:800}.classic-auto__tag,.classic-auto__count{font-size:9px;font-weight:700;letter-spacing:.16em;padding:0 4px;border-radius:999px;background:#fff3}.classic-auto__icon{width:32px;height:32px;border-radius:999px;border:2px solid rgba(255,255,255,.3);display:flex;align-items:center;justify-content:center}.classic-turn{font-size:20px;font-weight:800;letter-spacing:.22em;color:#fff;text-shadow:2px 2px 0 rgba(0,0,0,.7)}.classic-btn{display:inline-flex;align-items:center;gap:6px;padding:10px 16px;border-radius:999px;border:2px solid rgba(255,255,255,.4);font-size:12px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:#fff;background:#0009;transition:transform .15s ease,box-shadow .15s ease,opacity .15s ease}.classic-btn--play{background:var(--classic-btn-play);border-color:#fff9}.classic-btn--pass{background:var(--classic-btn-pass);border-color:#fff9}.classic-btn--hint{background:var(--classic-btn-hint);border-color:#fff6}.classic-btn:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none}.classic-btn:not(:disabled):hover{transform:translateY(-1px);box-shadow:0 10px 16px #00000059}.classic-btn:not(:disabled):active{transform:translateY(1px);box-shadow:0 6px 10px #00000040}.toast-classic{gap:12px}.toast-classic__icon{width:34px;height:34px;border-radius:999px;border:2px solid currentColor;display:flex;align-items:center;justify-content:center;color:var(--toast-color)}.toast-classic__text{display:flex;flex-direction:column;gap:2px}.toast-classic__title{font-size:16px;font-weight:800;letter-spacing:.2em;text-transform:uppercase;color:var(--toast-color);white-space:nowrap}.toast-classic__subtitle{font-size:10px;font-weight:700;letter-spacing:.28em;text-transform:uppercase;color:#fffc;white-space:nowrap}@keyframes festival-fall{0%{transform:translateY(-10px) rotate(0);opacity:.1}15%{opacity:.7}50%{transform:translateY(30px) rotate(12deg)}to{transform:translateY(80px) rotate(24deg);opacity:0}}.festival-card{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:space-between;padding:6px;pointer-events:auto;border-radius:var(--ui-radius);border:2px solid var(--ui-card-border);background:var(--ui-card-face);box-shadow:var(--ui-card-shadow);font-family:var(--ui-font-sans);font-weight:700;transition:transform .2s ease-out,box-shadow .2s ease-out;overflow:hidden}.festival-card.is-red{color:var(--ui-card-red)}.festival-card.is-black{color:var(--ui-card-black)}.festival-card.is-selected{border-color:var(--ui-accent);box-shadow:var(--ui-card-shadow-selected)}.festival-card.is-dimmed{opacity:.6}.festival-card--sm{padding:4px}.festival-card__label{font-size:16px;line-height:1}.festival-card--sm .festival-card__label{font-size:11px}.festival-card__label--top{align-self:flex-start}.festival-card__label--bottom{align-self:flex-end;transform:rotate(180deg)}.festival-card__suit{font-size:36px;line-height:1}.festival-card__suit--sm{font-size:18px}.festival-card__gloss{position:absolute;top:0;left:0;width:100%;height:40%;background:linear-gradient(180deg,var(--ui-card-gloss),transparent);opacity:.6;pointer-events:none}.festival-card--back{background:linear-gradient(160deg,var(--ui-card-back),var(--ui-card-back-2));border-color:var(--ui-card-back-border);color:var(--ui-panel-strong)}.festival-card__back-inner{position:absolute;inset:6px;border-radius:calc(var(--ui-radius) - 6px);border:2px solid var(--ui-card-back-line);background:radial-gradient(circle at 30% 30%,var(--ui-card-back-glow),transparent 60%),linear-gradient(135deg,var(--ui-card-back-sheen),transparent)}.festival-card__back-mark{position:relative;font-size:9px;letter-spacing:.3em;text-transform:uppercase;z-index:1}.festival-badge{display:flex;flex-direction:column;align-items:center;gap:6px;transition:transform .25s ease,opacity .25s ease}.festival-badge.is-turn{transform:scale(1.05);z-index:20}.festival-badge.is-idle{opacity:.9}.festival-badge.is-finished{opacity:.6;filter:grayscale(.4)}.festival-badge__halo{position:absolute;inset:-16px;border-radius:999px;background:var(--ui-accent);opacity:.12;filter:blur(16px);z-index:0}.festival-badge__avatar{position:relative;width:64px;height:64px;border-radius:999px;background:var(--ui-panel);border:2px solid var(--ui-border);box-shadow:var(--ui-shadow);display:flex;align-items:center;justify-content:center;z-index:1}.festival-badge__icon{color:var(--ui-muted)}.festival-badge__rank{position:absolute;bottom:-10px;padding:2px 10px;border-radius:999px;font-size:10px;font-weight:700;display:inline-flex;align-items:center;gap:4px;background:var(--ui-panel);border:1px solid var(--ui-border);color:var(--ui-muted);text-transform:uppercase;letter-spacing:.08em;box-shadow:var(--ui-shadow);white-space:nowrap}.festival-badge__rank.is-top{background:var(--ui-rank-top-bg);border-color:var(--ui-rank-top-border);color:var(--ui-rank-top-text)}.festival-badge__rank.is-dead{background:var(--ui-rank-dead-bg);border-color:var(--ui-rank-dead-border);color:var(--ui-rank-dead-text)}.festival-badge__crown{color:currentColor}.festival-badge__meta{display:flex;flex-direction:column;align-items:center;gap:2px}.festival-badge__name{font-size:10px;font-weight:700;color:var(--ui-muted);background:var(--ui-hud-pill);padding:2px 8px;border-radius:999px;letter-spacing:.08em;text-transform:uppercase}.festival-badge__count{display:inline-flex;align-items:center;gap:6px;padding:2px 10px;border-radius:999px;background:var(--ui-accent-2);color:var(--ui-panel-strong);font-size:12px;font-weight:700;letter-spacing:.08em}.festival-badge__finish{display:flex;flex-direction:column;align-items:center;color:var(--ui-text)}.festival-badge__finish-title{font-size:16px;font-weight:800}.festival-badge__finish-sub{font-size:8px;letter-spacing:.24em}.festival-hud{display:flex;flex-direction:column;align-items:flex-start;gap:8px}.festival-hud__row{display:flex;gap:8px}.festival-hud__pill{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:999px;background:var(--ui-hud-pill);border:1px solid var(--ui-hud-pill-border);color:var(--ui-hud-pill-text);font-weight:700;font-size:11px;letter-spacing:.12em;text-transform:uppercase;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.festival-hud__pill--accent{background:var(--ui-hud-pill-accent)}.festival-hud__pill--muted{background:var(--ui-panel);border-color:var(--ui-border-soft);color:var(--ui-muted);text-transform:none;letter-spacing:.06em}.festival-hud__brand{padding:6px 14px}.festival-hud__brand-text{font-size:12px;font-weight:800;letter-spacing:.2em}.festival-hud__icon{display:inline-flex;color:var(--ui-accent)}.festival-hud__label{font-size:10px;color:var(--ui-muted)}.festival-hud__value{font-size:12px;font-weight:800;color:var(--ui-text)}.festival-indicator{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:999px;border:1px solid var(--ui-accent-2);color:var(--ui-accent-2);background:var(--ui-hud-pill);font-size:10px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;transition:opacity .18s ease,transform .18s ease,max-height .18s ease;overflow:hidden;max-height:24px}.festival-indicator--on{opacity:1;transform:translateY(0) scale(1)}.festival-indicator--off{opacity:0;transform:translateY(-4px) scale(.98);max-height:0;margin-top:0}.festival-indicator__icon{width:14px;height:14px}.festival-indicator__text{font-size:10px}.festival-action__turn{align-self:flex-end;padding:4px 12px;border-radius:999px;background:var(--ui-hud-pill-accent);color:var(--ui-text);font-weight:800;letter-spacing:.14em;text-transform:uppercase;font-size:12px;margin-bottom:6px}.festival-auto{display:inline-flex;align-items:center;gap:10px;padding:8px 12px;border-radius:999px;background:var(--ui-hud-pill);border:1px solid var(--ui-hud-pill-border);color:var(--ui-hud-pill-text);box-shadow:var(--ui-shadow);transition:transform .18s ease,box-shadow .18s ease}.festival-auto.is-on{border-color:var(--ui-accent);color:var(--ui-text)}.festival-auto__meta{display:flex;flex-direction:column;align-items:flex-end;gap:2px;font-size:9px;letter-spacing:.14em;text-transform:uppercase}.festival-auto__label{font-weight:800;font-size:10px}.festival-auto__status{font-weight:700;color:var(--ui-muted)}.festival-auto__tag{background:var(--ui-accent);color:var(--ui-panel-strong);padding:2px 6px;border-radius:999px;font-size:8px}.festival-auto__count{color:var(--ui-muted)}.festival-auto__icon{width:32px;height:32px;border-radius:999px;background:var(--ui-hud-pill);display:flex;align-items:center;justify-content:center;color:var(--ui-accent-2);border:1px solid var(--ui-border-soft)}@keyframes p5-toast{0%{opacity:0;transform:skew(-20deg) translateY(8px) scale(.96)}18%{opacity:1;transform:skew(-20deg) translateY(0) scale(1)}78%{opacity:1;transform:skew(-20deg) translateY(0) scale(1)}to{opacity:0;transform:skew(-20deg) translateY(-6px) scale(.98)}}@keyframes p5-toast-flip{0%{transform:skew(-20deg) translateY(6px) rotateX(60deg);opacity:0}18%{transform:skew(-20deg) translateY(0) rotateX(0);opacity:1}78%{transform:skew(-20deg) translateY(0) rotateX(0);opacity:1}to{transform:skew(-20deg) translateY(-6px) rotateX(0);opacity:0}}@keyframes p5-toast-cut{0%{opacity:0;transform:translateY(-6px)}20%{opacity:1;transform:translateY(0)}70%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(6px)}}@keyframes p5-toast-stamp{0%{opacity:0;transform:skew(-20deg) translateY(-10px) scale(1.1)}22%{opacity:1;transform:skew(-20deg) translateY(0) scale(1)}78%{opacity:1;transform:skew(-20deg) translateY(0) scale(1)}to{opacity:0;transform:skew(-20deg) translateY(-4px) scale(.98)}}@keyframes p5-toast-swap{0%{opacity:0;transform:translate(6px,-50%) skew(-20deg)}22%{opacity:1;transform:translateY(-50%) skew(-20deg)}78%{opacity:1;transform:translateY(-50%) skew(-20deg)}to{opacity:0;transform:translate(-6px,-50%) skew(-20deg)}}@keyframes p5-toast-fall{0%{opacity:0;transform:skew(-20deg) translateY(-10px)}22%{opacity:1;transform:skew(-20deg) translateY(0)}78%{opacity:1;transform:skew(-20deg) translateY(0)}to{opacity:0;transform:skew(-20deg) translateY(10px)}}@keyframes p5-toast-rise{0%{opacity:0;transform:skew(-20deg) translateY(10px)}22%{opacity:1;transform:skew(-20deg) translateY(0)}78%{opacity:1;transform:skew(-20deg) translateY(0)}to{opacity:0;transform:skew(-20deg) translateY(-10px)}}@keyframes toast-generic{0%{opacity:0;transform:translateY(8px) scale(.96)}18%{opacity:1;transform:translateY(0) scale(1)}78%{opacity:1;transform:translateY(0) scale(1)}to{opacity:0;transform:translateY(-6px) scale(.98)}}@keyframes toast-revolution{0%{opacity:0;transform:translateY(6px) rotateX(70deg)}20%{opacity:1;transform:translateY(0) rotateX(0)}78%{opacity:1;transform:translateY(0) rotateX(0)}to{opacity:0;transform:translateY(-6px) rotateX(0)}}@keyframes toast-counter{0%{opacity:0;transform:translateY(6px) rotateX(-30deg)}22%{opacity:1;transform:translateY(0) rotateX(-12deg)}60%{opacity:1;transform:translateY(0) rotateX(0)}to{opacity:0;transform:translateY(-6px) rotateX(0)}}@keyframes toast-crown-drop{0%{opacity:0;transform:translateY(-10px) rotate(0)}20%{opacity:1;transform:translateY(0) rotate(0)}70%{opacity:1;transform:translateY(0) rotate(0)}to{opacity:0;transform:translateY(20px) rotate(-18deg)}}@keyframes toast-stamp{0%{opacity:0;transform:translateY(-12px) scale(1.1)}20%{opacity:1;transform:translateY(0) scale(1)}80%{opacity:1;transform:translateY(0) scale(1)}to{opacity:0;transform:translateY(-4px) scale(.98)}}@keyframes toast-joker{0%{opacity:0;transform:translate(18px)}20%{opacity:1;transform:translate(0)}70%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(-18px)}}@keyframes toast-tribute{0%{opacity:0;transform:translateY(6px) scaleX(.94)}24%{opacity:1;transform:translateY(0) scaleX(1)}80%{opacity:1;transform:translateY(0) scaleX(1)}to{opacity:0;transform:translateY(-6px) scaleX(.98)}}@keyframes toast-cut-line{0%{opacity:0;transform:translateY(-50%) rotate(-12deg) scaleX(0)}18%{opacity:1;transform:translateY(-50%) rotate(-12deg) scaleX(1)}80%{opacity:1}to{opacity:0}}@keyframes toast-cut-left{0%{opacity:0;transform:translateY(8px) scale(.96)}20%{opacity:1;transform:translateY(0) scale(1)}78%{opacity:1;transform:translateY(0) scale(1)}to{opacity:0;transform:translate(-16px,-6px) scale(.98)}}@keyframes toast-cut-right{0%{opacity:0;transform:translateY(8px) scale(.96)}20%{opacity:1;transform:translateY(0) scale(1)}78%{opacity:1;transform:translateY(0) scale(1)}to{opacity:0;transform:translate(16px,-6px) scale(.98)}}@keyframes toast-dot{0%{opacity:.2}30%{opacity:1}60%{opacity:.2}to{opacity:.2}}.btn-cta{position:relative;background:#151515;color:#f8fafc;border:2px solid rgba(255,60,60,.8);clip-path:polygon(0 0,92% 0,100% 18%,100% 100%,8% 100%,0 82%);box-shadow:0 10px 20px #00000059;transform:skew(-10deg);transition:transform .12s ease,box-shadow .12s ease,border-color .12s ease}.btn-cta:hover:not(:disabled){box-shadow:0 0 0 1px #ff3c3ccc,0 0 18px #ff3c3c59;transform:skew(-10deg) translateY(-1px)}.btn-cta:active:not(:disabled){box-shadow:0 0 0 1px #ff3c3c99,0 0 10px #ff3c3c33;transform:skew(-10deg) translateY(0)}.btn-cta:disabled{border-color:#ff3c3c40;color:#9ca3afe6;box-shadow:none;cursor:not-allowed}.hover\:scale-105:hover{--tw-scale-x: 1.05;--tw-scale-y: 1.05;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))}.hover\:bg-white\/10:hover{background-color:#ffffff1a}.active\:scale-95:active{--tw-scale-x: .95;--tw-scale-y: .95;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))}.group:hover .group-hover\:translate-x-\[100\%\]{--tw-translate-x: 100%;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))}.group:hover .group-hover\:scale-110{--tw-scale-x: 1.1;--tw-scale-y: 1.1;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))}.group:hover .group-hover\:bg-crimson-500{--tw-bg-opacity: 1;background-color:rgb(255 0 30 / var(--tw-bg-opacity, 1))}.group:hover .group-hover\:bg-gray-900{--tw-bg-opacity: 1;background-color:rgb(17 24 39 / var(--tw-bg-opacity, 1))}.group:hover .group-hover\:text-white{--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity, 1))}.group:hover .group-hover\:opacity-10{opacity:.1}.group:hover .group-hover\:opacity-100{opacity:1}@media(min-width:640px){.sm\:block{display:block}.sm\:h-20{height:5rem}.sm\:w-20{width:5rem}.sm\:text-2xl{font-size:1.5rem;line-height:2rem}.sm\:text-5xl{font-size:3rem;line-height:1}.sm\:text-\[10px\]{font-size:10px}}
