:root{--neon-blue: #646cff;--neon-purple: #535bf2;--neon-blue-light: #747bff;--neon-blue-soft: #667eea;--bg-dark-primary: #242424;--bg-dark-secondary: #1a1a1a;--bg-dark-tertiary: #1a1a2e;--bg-dark-gradient: #16213e;--success-primary: #4caf50;--success-bright: #66bb6a;--success-soft: #26a69a;--success-neon: #64ffda;--success-emerald: #43e97b;--error-primary: #ef5350;--error-bright: #ff6b6b;--error-soft: #f4436c;--warning-primary: #ff9800;--warning-bright: #ffa726;--warning-amber: #ffc107;--board-light: #f0d9b5;--board-dark: #b58863;--board-selected: rgba(255, 255, 0, .4);--board-last-move: rgba(255, 215, 0, .8);--board-size-mobile: 98vw;--board-size-tablet: 100%;--board-size-desktop: 560px;--text-primary: #e0e0e0;--text-secondary: #9e9e9e;--text-tertiary: #999;--text-white: #fff;--glow-blue-sm: 0 4px 12px rgba(102, 126, 234, .3);--glow-blue-md: 0 6px 12px rgba(102, 126, 234, .4);--glow-green-sm: 0 4px 12px rgba(76, 175, 80, .3);--glow-green-md: 0 0 20px rgba(76, 175, 80, .3);--glow-cyan: 0 4px 8px rgba(100, 255, 218, .3);--glow-red: 0 4px 8px rgba(245, 87, 108, .4);--shadow-sm: 0 2px 4px rgba(0, 0, 0, .2);--shadow-md: 0 4px 12px rgba(0, 0, 0, .3);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .4);--shadow-xl: 0 10px 40px rgba(0, 0, 0, .5)}@keyframes slide-up{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}.animate-slide-up{animation:slide-up .3s ease-out forwards}*,: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: }::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: }*{box-sizing:border-box}html{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh;color:#ffffffde;background-color:var(--bg-dark-primary)}#root{margin:0 auto;width:100%}a{font-weight:500;color:var(--neon-blue);text-decoration:inherit}a:hover{color:var(--neon-purple)}h1{font-size:3.2em;line-height:1.1}h2{font-size:2rem}h3{font-size:1.5rem}.text-mono{font-family:monospace}.text-emphasis{font-size:1.125rem;font-weight:600}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:var(--bg-dark-secondary);cursor:pointer;transition:border-color .25s}button:hover{border-color:var(--neon-blue)}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}input[type=text],textarea{width:100%;padding:12px 16px;border-radius:8px;background:var(--bg-dark-secondary);border:1px solid #444;color:var(--text-primary);font-family:inherit}input:focus,textarea:focus{outline:none;border-color:var(--neon-blue);box-shadow:var(--glow-blue-sm)}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:var(--neon-blue-light)}button{background-color:#f9f9f9}}.custom-board-wrapper{position:relative;margin:0 auto;-webkit-user-select:none;-moz-user-select:none;user-select:none;width:100%;height:auto;aspect-ratio:1;max-width:100%}@media(min-width:768px){.custom-board-wrapper{width:var(--board-size-tablet);height:var(--board-size-tablet)}}@media(min-width:1024px){.custom-board-wrapper{width:var(--board-size-desktop);height:var(--board-size-desktop)}}.custom-board{display:grid;grid-template-columns:repeat(8,1fr);grid-template-rows:repeat(8,1fr);width:100%;height:100%;border-radius:4px;overflow:hidden;box-shadow:0 5px 15px #00000080}.square{position:relative;width:100%;height:100%;display:flex;align-items:center;justify-content:center;min-width:35px;min-height:35px}.square.light{background-color:var(--board-light)}.square.dark{background-color:var(--board-dark)}.square.selected{background-color:var(--board-selected)!important}.square.last-move{background-color:#ff06!important}.square.hint-square{background-color:#f59e0b80!important;box-shadow:inset 0 0 20px #f59e0b99;animation:hint-pulse 1.5s ease-in-out infinite}@keyframes hint-pulse{0%,to{background-color:#f59e0b80!important;box-shadow:inset 0 0 20px #f59e0b99}50%{background-color:#f9731699!important;box-shadow:inset 0 0 30px #f97316cc}}.puzzle-board-display{display:flex;justify-content:center;align-items:center;padding:2px}.chessboard{display:flex;flex-direction:column;border:3px solid #444;box-shadow:var(--shadow-lg);border-radius:4px}.board-rank{display:flex}.puzzle-board-display .square{width:calc(var(--board-size-mobile) / 8);height:calc(var(--board-size-mobile) / 8);cursor:pointer;transition:all .2s ease}@media(min-width:768px){.puzzle-board-display .square{width:calc(var(--board-size-tablet) / 8);height:calc(var(--board-size-tablet) / 8)}}@media(min-width:1024px){.puzzle-board-display .square{width:70px;height:70px}}.square.disabled,.square.disabled .piece{cursor:not-allowed}.chess-board-container{position:relative;display:inline-block;margin:20px auto;width:var(--board-size-mobile);max-width:100%}@media(min-width:768px){.chess-board-container{width:var(--board-size-tablet)}}@media(min-width:1024px){.chess-board-container{width:var(--board-size-desktop)}}@media(max-width:768px){.chess-board-container{margin:8px auto}}.game-over-message{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:#000000d9;color:#fff;padding:30px 60px;border-radius:12px;text-align:center;box-shadow:0 8px 24px #0000004d;z-index:10}.game-over-message h2{margin:0 0 10px;font-size:32px;font-weight:700}.game-over-message p{margin:0;font-size:20px}@media(max-width:768px){.game-over-message{padding:20px 40px}.game-over-message h2{font-size:24px}.game-over-message p{font-size:16px}}.pointer-events-none{pointer-events:none}.visible{visibility:visible}.static{position:static}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.sticky{position:sticky}.inset-0{inset:0}.-left-2{left:-.5rem}.-right-1{right:-.25rem}.-top-1{top:-.25rem}.bottom-0{bottom:0}.bottom-full{bottom:100%}.left-0{left:0}.left-1\/2{left:50%}.left-2{left:.5rem}.right-0{right:0}.right-1\/4{right:25%}.right-3{right:.75rem}.right-4{right:1rem}.top-0{top:0}.top-1\/2{top:50%}.top-2{top:.5rem}.top-3{top:.75rem}.z-10{z-index:10}.z-20{z-index:20}.z-30{z-index:30}.z-40{z-index:40}.z-50{z-index:50}.m-0{margin:0}.mx-1{margin-left:.25rem;margin-right:.25rem}.mx-2{margin-left:.5rem;margin-right:.5rem}.mx-4{margin-left:1rem;margin-right:1rem}.mx-auto{margin-left:auto;margin-right:auto}.my-1{margin-top:.25rem;margin-bottom:.25rem}.my-4{margin-top:1rem;margin-bottom:1rem}.-ml-0{margin-left:-0px}.-ml-0\.5{margin-left:-.125rem}.mb-0{margin-bottom:0}.mb-0\.5{margin-bottom:.125rem}.mb-1{margin-bottom:.25rem}.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}.mb-5{margin-bottom:1.25rem}.mb-6{margin-bottom:1.5rem}.mb-8{margin-bottom:2rem}.ml-0{margin-left:0}.ml-1{margin-left:.25rem}.ml-2{margin-left:.5rem}.ml-3{margin-left:.75rem}.ml-auto{margin-left:auto}.mt-0{margin-top:0}.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-6{margin-top:1.5rem}.mt-auto{margin-top:auto}.block{display:block}.inline-block{display:inline-block}.inline{display:inline}.flex{display:flex}.inline-flex{display:inline-flex}.table{display:table}.grid{display:grid}.hidden{display:none}.aspect-square{aspect-ratio:1 / 1}.h-0{height:0px}.h-0\.5{height:.125rem}.h-1{height:.25rem}.h-1\.5{height:.375rem}.h-10{height:2.5rem}.h-12{height:3rem}.h-14{height:3.5rem}.h-16{height:4rem}.h-2{height:.5rem}.h-20{height:5rem}.h-3{height:.75rem}.h-32{height:8rem}.h-4{height:1rem}.h-40{height:10rem}.h-48{height:12rem}.h-5{height:1.25rem}.h-6{height:1.5rem}.h-64{height:16rem}.h-8{height:2rem}.h-9{height:2.25rem}.h-\[500px\]{height:500px}.h-\[600px\]{height:600px}.h-\[min\(calc\(100vw-3rem\)\,calc\(100vh-16rem\)\)\]{height:min(calc(100vw - 3rem),calc(100vh - 16rem))}.h-full{height:100%}.h-px{height:1px}.max-h-48{max-height:12rem}.max-h-60{max-height:15rem}.max-h-\[400px\]{max-height:400px}.max-h-\[500px\]{max-height:500px}.max-h-\[600px\]{max-height:600px}.max-h-\[60vh\]{max-height:60vh}.max-h-\[80vh\]{max-height:80vh}.max-h-\[90vh\]{max-height:90vh}.max-h-\[calc\(100vw-1\.5rem\)\]{max-height:calc(100vw - 1.5rem)}.max-h-full{max-height:100%}.min-h-0{min-height:0px}.min-h-\[150px\]{min-height:150px}.min-h-screen{min-height:100vh}.w-0{width:0px}.w-1\/2{width:50%}.w-10{width:2.5rem}.w-12{width:3rem}.w-14{width:3.5rem}.w-16{width:4rem}.w-2{width:.5rem}.w-20{width:5rem}.w-3{width:.75rem}.w-4{width:1rem}.w-5{width:1.25rem}.w-6{width:1.5rem}.w-7{width:1.75rem}.w-8{width:2rem}.w-80{width:20rem}.w-9{width:2.25rem}.w-\[200px\]{width:200px}.w-\[45px\]{width:45px}.w-\[500px\]{width:500px}.w-full{width:100%}.w-px{width:1px}.min-w-0{min-width:0px}.min-w-\[120px\]{min-width:120px}.min-w-\[280px\]{min-width:280px}.min-w-\[80px\]{min-width:80px}.max-w-2xl{max-width:42rem}.max-w-5xl{max-width:64rem}.max-w-6xl{max-width:72rem}.max-w-7xl{max-width:80rem}.max-w-\[150px\]{max-width:150px}.max-w-\[180px\]{max-width:180px}.max-w-\[250px\]{max-width:250px}.max-w-\[260px\]{max-width:260px}.max-w-\[300px\]{max-width:300px}.max-w-\[40\%\]{max-width:40%}.max-w-\[500px\]{max-width:500px}.max-w-\[600px\]{max-width:600px}.max-w-\[calc\(100vw-1\.5rem\)\]{max-width:calc(100vw - 1.5rem)}.max-w-full{max-width:100%}.max-w-md{max-width:28rem}.max-w-sm{max-width:24rem}.flex-1{flex:1 1 0%}.flex-shrink-0,.shrink-0{flex-shrink:0}.-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-x-full{--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))}.-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-y-2{--tw-translate-y: -.5rem;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-0{--tw-translate-x: 0px;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-2{--tw-translate-y: .5rem;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-45{--tw-rotate: -45deg;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-45{--tw-rotate: 45deg;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-75{--tw-scale-x: .75;--tw-scale-y: .75;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 pulse{50%{opacity:.5}}.animate-pulse{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}.animate-spin{animation:spin 1s linear infinite}.cursor-help{cursor:help}.cursor-not-allowed{cursor:not-allowed}.cursor-pointer{cursor:pointer}.resize-none{resize:none}.resize{resize:both}.appearance-none{-webkit-appearance:none;-moz-appearance:none;appearance:none}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.grid-cols-5{grid-template-columns:repeat(5,minmax(0,1fr))}.grid-cols-\[auto_1fr_1fr\]{grid-template-columns:auto 1fr 1fr}.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}.items-stretch{align-items:stretch}.justify-end{justify-content:flex-end}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-0{gap:0px}.gap-0\.5{gap:.125rem}.gap-1{gap:.25rem}.gap-1\.5{gap:.375rem}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.gap-6{gap:1.5rem}.gap-x-2{-moz-column-gap:.5rem;column-gap:.5rem}.gap-x-3{-moz-column-gap:.75rem;column-gap:.75rem}.gap-x-4{-moz-column-gap:1rem;column-gap:1rem}.gap-y-1{row-gap:.25rem}.space-y-1>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.25rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.25rem * var(--tw-space-y-reverse))}.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))}.space-y-4>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(1rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1rem * var(--tw-space-y-reverse))}.space-y-6>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(1.5rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1.5rem * var(--tw-space-y-reverse))}.divide-y>:not([hidden])~:not([hidden]){--tw-divide-y-reverse: 0;border-top-width:calc(1px * calc(1 - var(--tw-divide-y-reverse)));border-bottom-width:calc(1px * var(--tw-divide-y-reverse))}.divide-slate-700>:not([hidden])~:not([hidden]){--tw-divide-opacity: 1;border-color:rgb(51 65 85 / var(--tw-divide-opacity))}.self-stretch{align-self:stretch}.overflow-hidden{overflow:hidden}.overflow-x-auto{overflow-x:auto}.overflow-y-auto{overflow-y:auto}.overflow-x-hidden{overflow-x:hidden}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.whitespace-nowrap{white-space:nowrap}.break-all{word-break:break-all}.rounded{border-radius:.25rem}.rounded-2xl{border-radius:1rem}.rounded-full{border-radius:9999px}.rounded-lg{border-radius:.5rem}.rounded-none{border-radius:0}.rounded-xl{border-radius:.75rem}.rounded-b-lg{border-bottom-right-radius:.5rem;border-bottom-left-radius:.5rem}.rounded-b-xl{border-bottom-right-radius:.75rem;border-bottom-left-radius:.75rem}.rounded-t-2xl{border-top-left-radius:1rem;border-top-right-radius:1rem}.rounded-t-lg{border-top-left-radius:.5rem;border-top-right-radius:.5rem}.rounded-tl-none{border-top-left-radius:0}.border{border-width:1px}.border-0{border-width:0px}.border-2{border-width:2px}.border-4{border-width:4px}.border-b{border-bottom-width:1px}.border-b-2{border-bottom-width:2px}.border-l-4{border-left-width:4px}.border-l-\[8px\]{border-left-width:8px}.border-r{border-right-width:1px}.border-t{border-top-width:1px}.border-t-\[8px\]{border-top-width:8px}.border-dashed{border-style:dashed}.border-none{border-style:none}.border-amber-500\/20{border-color:#f59e0b33}.border-amber-500\/50{border-color:#f59e0b80}.border-amber-600\/30{border-color:#d977064d}.border-blue-500{--tw-border-opacity: 1;border-color:rgb(59 130 246 / var(--tw-border-opacity))}.border-blue-500\/20{border-color:#3b82f633}.border-blue-500\/30{border-color:#3b82f64d}.border-blue-500\/40{border-color:#3b82f666}.border-blue-500\/50{border-color:#3b82f680}.border-blue-900\/30{border-color:#1e3a8a4d}.border-emerald-400{--tw-border-opacity: 1;border-color:rgb(52 211 153 / var(--tw-border-opacity))}.border-gray-300{--tw-border-opacity: 1;border-color:rgb(209 213 219 / var(--tw-border-opacity))}.border-gray-400{--tw-border-opacity: 1;border-color:rgb(156 163 175 / var(--tw-border-opacity))}.border-gray-500\/30{border-color:#6b72804d}.border-gray-600{--tw-border-opacity: 1;border-color:rgb(75 85 99 / var(--tw-border-opacity))}.border-gray-700{--tw-border-opacity: 1;border-color:rgb(55 65 81 / var(--tw-border-opacity))}.border-green-500{--tw-border-opacity: 1;border-color:rgb(34 197 94 / var(--tw-border-opacity))}.border-green-500\/30{border-color:#22c55e4d}.border-green-600\/30{border-color:#16a34a4d}.border-green-700\/30{border-color:#15803d4d}.border-green-700\/50{border-color:#15803d80}.border-indigo-500\/30{border-color:#6366f14d}.border-neutral-700{--tw-border-opacity: 1;border-color:rgb(64 64 64 / var(--tw-border-opacity))}.border-pink-500\/30{border-color:#ec48994d}.border-purple-500{--tw-border-opacity: 1;border-color:rgb(168 85 247 / var(--tw-border-opacity))}.border-purple-500\/30{border-color:#a855f74d}.border-purple-500\/50{border-color:#a855f780}.border-purple-600\/30{border-color:#9333ea4d}.border-red-500{--tw-border-opacity: 1;border-color:rgb(239 68 68 / var(--tw-border-opacity))}.border-red-500\/30{border-color:#ef44444d}.border-red-500\/50{border-color:#ef444480}.border-red-700\/50{border-color:#b91c1c80}.border-slate-600{--tw-border-opacity: 1;border-color:rgb(71 85 105 / var(--tw-border-opacity))}.border-slate-600\/50{border-color:#47556980}.border-slate-700{--tw-border-opacity: 1;border-color:rgb(51 65 85 / var(--tw-border-opacity))}.border-slate-700\/30{border-color:#3341554d}.border-slate-700\/50{border-color:#33415580}.border-slate-800{--tw-border-opacity: 1;border-color:rgb(30 41 59 / var(--tw-border-opacity))}.border-transparent{border-color:transparent}.border-white{--tw-border-opacity: 1;border-color:rgb(255 255 255 / var(--tw-border-opacity))}.border-white\/10{border-color:#ffffff1a}.border-white\/30{border-color:#ffffff4d}.border-yellow-500\/50{border-color:#eab30880}.border-l-transparent{border-left-color:transparent}.border-t-transparent{border-top-color:transparent}.border-t-white{--tw-border-opacity: 1;border-top-color:rgb(255 255 255 / var(--tw-border-opacity))}.bg-\[\#1a1816\]{--tw-bg-opacity: 1;background-color:rgb(26 24 22 / var(--tw-bg-opacity))}.bg-\[\#262421\]{--tw-bg-opacity: 1;background-color:rgb(38 36 33 / var(--tw-bg-opacity))}.bg-\[rgba\(38\,36\,33\,0\.60\)\]{background-color:#26242199}.bg-\[rgba\(38\,36\,33\,0\.95\)\]{background-color:#262421f2}.bg-amber-500{--tw-bg-opacity: 1;background-color:rgb(245 158 11 / var(--tw-bg-opacity))}.bg-amber-500\/10{background-color:#f59e0b1a}.bg-amber-500\/20{background-color:#f59e0b33}.bg-amber-600{--tw-bg-opacity: 1;background-color:rgb(217 119 6 / var(--tw-bg-opacity))}.bg-amber-700\/20{background-color:#b4530933}.bg-amber-900\/20{background-color:#78350f33}.bg-black{--tw-bg-opacity: 1;background-color:rgb(0 0 0 / var(--tw-bg-opacity))}.bg-black\/20{background-color:#0003}.bg-black\/50{background-color:#00000080}.bg-black\/60{background-color:#0009}.bg-black\/70{background-color:#000000b3}.bg-black\/75{background-color:#000000bf}.bg-blue-500{--tw-bg-opacity: 1;background-color:rgb(59 130 246 / var(--tw-bg-opacity))}.bg-blue-500\/10{background-color:#3b82f61a}.bg-blue-500\/20{background-color:#3b82f633}.bg-blue-500\/30{background-color:#3b82f64d}.bg-blue-600{--tw-bg-opacity: 1;background-color:rgb(37 99 235 / var(--tw-bg-opacity))}.bg-blue-600\/10{background-color:#2563eb1a}.bg-blue-600\/20{background-color:#2563eb33}.bg-blue-600\/30{background-color:#2563eb4d}.bg-blue-900\/30{background-color:#1e3a8a4d}.bg-emerald-400{--tw-bg-opacity: 1;background-color:rgb(52 211 153 / var(--tw-bg-opacity))}.bg-emerald-500{--tw-bg-opacity: 1;background-color:rgb(16 185 129 / var(--tw-bg-opacity))}.bg-emerald-500\/10{background-color:#10b9811a}.bg-emerald-600{--tw-bg-opacity: 1;background-color:rgb(5 150 105 / var(--tw-bg-opacity))}.bg-gray-200{--tw-bg-opacity: 1;background-color:rgb(229 231 235 / var(--tw-bg-opacity))}.bg-gray-300{--tw-bg-opacity: 1;background-color:rgb(209 213 219 / var(--tw-bg-opacity))}.bg-gray-500{--tw-bg-opacity: 1;background-color:rgb(107 114 128 / var(--tw-bg-opacity))}.bg-gray-500\/20{background-color:#6b728033}.bg-gray-600{--tw-bg-opacity: 1;background-color:rgb(75 85 99 / var(--tw-bg-opacity))}.bg-gray-600\/20{background-color:#4b556333}.bg-gray-600\/30{background-color:#4b55634d}.bg-gray-700{--tw-bg-opacity: 1;background-color:rgb(55 65 81 / var(--tw-bg-opacity))}.bg-gray-800{--tw-bg-opacity: 1;background-color:rgb(31 41 55 / var(--tw-bg-opacity))}.bg-gray-800\/50{background-color:#1f293780}.bg-gray-900{--tw-bg-opacity: 1;background-color:rgb(17 24 39 / var(--tw-bg-opacity))}.bg-gray-900\/50{background-color:#11182780}.bg-gray-900\/80{background-color:#111827cc}.bg-green-300{--tw-bg-opacity: 1;background-color:rgb(134 239 172 / var(--tw-bg-opacity))}.bg-green-400{--tw-bg-opacity: 1;background-color:rgb(74 222 128 / var(--tw-bg-opacity))}.bg-green-500{--tw-bg-opacity: 1;background-color:rgb(34 197 94 / var(--tw-bg-opacity))}.bg-green-500\/10{background-color:#22c55e1a}.bg-green-500\/20{background-color:#22c55e33}.bg-green-600{--tw-bg-opacity: 1;background-color:rgb(22 163 74 / var(--tw-bg-opacity))}.bg-green-600\/20{background-color:#16a34a33}.bg-green-900\/20{background-color:#14532d33}.bg-green-900\/30{background-color:#14532d4d}.bg-indigo-500\/10{background-color:#6366f11a}.bg-neutral-700{--tw-bg-opacity: 1;background-color:rgb(64 64 64 / var(--tw-bg-opacity))}.bg-neutral-800{--tw-bg-opacity: 1;background-color:rgb(38 38 38 / var(--tw-bg-opacity))}.bg-neutral-900{--tw-bg-opacity: 1;background-color:rgb(23 23 23 / var(--tw-bg-opacity))}.bg-orange-400{--tw-bg-opacity: 1;background-color:rgb(251 146 60 / var(--tw-bg-opacity))}.bg-orange-600{--tw-bg-opacity: 1;background-color:rgb(234 88 12 / var(--tw-bg-opacity))}.bg-pink-500\/10{background-color:#ec48991a}.bg-purple-600{--tw-bg-opacity: 1;background-color:rgb(147 51 234 / var(--tw-bg-opacity))}.bg-purple-600\/20{background-color:#9333ea33}.bg-purple-600\/30{background-color:#9333ea4d}.bg-purple-600\/40{background-color:#9333ea66}.bg-purple-600\/80{background-color:#9333eacc}.bg-red-500{--tw-bg-opacity: 1;background-color:rgb(239 68 68 / var(--tw-bg-opacity))}.bg-red-500\/10{background-color:#ef44441a}.bg-red-500\/20{background-color:#ef444433}.bg-red-600{--tw-bg-opacity: 1;background-color:rgb(220 38 38 / var(--tw-bg-opacity))}.bg-red-600\/20{background-color:#dc262633}.bg-red-600\/80{background-color:#dc2626cc}.bg-red-700{--tw-bg-opacity: 1;background-color:rgb(185 28 28 / var(--tw-bg-opacity))}.bg-red-900\/30{background-color:#7f1d1d4d}.bg-red-900\/50{background-color:#7f1d1d80}.bg-slate-500{--tw-bg-opacity: 1;background-color:rgb(100 116 139 / var(--tw-bg-opacity))}.bg-slate-600{--tw-bg-opacity: 1;background-color:rgb(71 85 105 / var(--tw-bg-opacity))}.bg-slate-700{--tw-bg-opacity: 1;background-color:rgb(51 65 85 / var(--tw-bg-opacity))}.bg-slate-700\/30{background-color:#3341554d}.bg-slate-700\/40{background-color:#33415566}.bg-slate-700\/50{background-color:#33415580}.bg-slate-800{--tw-bg-opacity: 1;background-color:rgb(30 41 59 / var(--tw-bg-opacity))}.bg-slate-800\/30{background-color:#1e293b4d}.bg-slate-800\/50{background-color:#1e293b80}.bg-slate-800\/80{background-color:#1e293bcc}.bg-slate-800\/90{background-color:#1e293be6}.bg-slate-800\/95{background-color:#1e293bf2}.bg-slate-900{--tw-bg-opacity: 1;background-color:rgb(15 23 42 / var(--tw-bg-opacity))}.bg-slate-900\/30{background-color:#0f172a4d}.bg-slate-900\/40{background-color:#0f172a66}.bg-slate-900\/50{background-color:#0f172a80}.bg-teal-500{--tw-bg-opacity: 1;background-color:rgb(20 184 166 / var(--tw-bg-opacity))}.bg-white{--tw-bg-opacity: 1;background-color:rgb(255 255 255 / var(--tw-bg-opacity))}.bg-white\/10{background-color:#ffffff1a}.bg-white\/20{background-color:#fff3}.bg-yellow-400{--tw-bg-opacity: 1;background-color:rgb(250 204 21 / var(--tw-bg-opacity))}.bg-yellow-500{--tw-bg-opacity: 1;background-color:rgb(234 179 8 / var(--tw-bg-opacity))}.bg-yellow-500\/20{background-color:#eab30833}.bg-yellow-600{--tw-bg-opacity: 1;background-color:rgb(202 138 4 / var(--tw-bg-opacity))}.bg-yellow-600\/20{background-color:#ca8a0433}.bg-gradient-to-br{background-image:linear-gradient(to bottom right,var(--tw-gradient-stops))}.bg-gradient-to-r{background-image:linear-gradient(to right,var(--tw-gradient-stops))}.from-amber-500{--tw-gradient-from: #f59e0b var(--tw-gradient-from-position);--tw-gradient-to: rgb(245 158 11 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-amber-600\/30{--tw-gradient-from: rgb(217 119 6 / .3) var(--tw-gradient-from-position);--tw-gradient-to: rgb(217 119 6 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-blue-500{--tw-gradient-from: #3b82f6 var(--tw-gradient-from-position);--tw-gradient-to: rgb(59 130 246 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-blue-600{--tw-gradient-from: #2563eb var(--tw-gradient-from-position);--tw-gradient-to: rgb(37 99 235 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-emerald-500{--tw-gradient-from: #10b981 var(--tw-gradient-from-position);--tw-gradient-to: rgb(16 185 129 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-emerald-600{--tw-gradient-from: #059669 var(--tw-gradient-from-position);--tw-gradient-to: rgb(5 150 105 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-fuchsia-600{--tw-gradient-from: #c026d3 var(--tw-gradient-from-position);--tw-gradient-to: rgb(192 38 211 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-gray-600{--tw-gradient-from: #4b5563 var(--tw-gradient-from-position);--tw-gradient-to: rgb(75 85 99 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-green-500{--tw-gradient-from: #22c55e var(--tw-gradient-from-position);--tw-gradient-to: rgb(34 197 94 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-green-600{--tw-gradient-from: #16a34a var(--tw-gradient-from-position);--tw-gradient-to: rgb(22 163 74 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-green-900\/30{--tw-gradient-from: rgb(20 83 45 / .3) var(--tw-gradient-from-position);--tw-gradient-to: rgb(20 83 45 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-indigo-600\/20{--tw-gradient-from: rgb(79 70 229 / .2) var(--tw-gradient-from-position);--tw-gradient-to: rgb(79 70 229 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-orange-600{--tw-gradient-from: #ea580c var(--tw-gradient-from-position);--tw-gradient-to: rgb(234 88 12 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-pink-400{--tw-gradient-from: #f472b6 var(--tw-gradient-from-position);--tw-gradient-to: rgb(244 114 182 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-pink-500{--tw-gradient-from: #ec4899 var(--tw-gradient-from-position);--tw-gradient-to: rgb(236 72 153 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-pink-600{--tw-gradient-from: #db2777 var(--tw-gradient-from-position);--tw-gradient-to: rgb(219 39 119 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-purple-400{--tw-gradient-from: #c084fc var(--tw-gradient-from-position);--tw-gradient-to: rgb(192 132 252 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-purple-500{--tw-gradient-from: #a855f7 var(--tw-gradient-from-position);--tw-gradient-to: rgb(168 85 247 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-purple-600{--tw-gradient-from: #9333ea var(--tw-gradient-from-position);--tw-gradient-to: rgb(147 51 234 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-red-500{--tw-gradient-from: #ef4444 var(--tw-gradient-from-position);--tw-gradient-to: rgb(239 68 68 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-red-600{--tw-gradient-from: #dc2626 var(--tw-gradient-from-position);--tw-gradient-to: rgb(220 38 38 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-slate-900{--tw-gradient-from: #0f172a var(--tw-gradient-from-position);--tw-gradient-to: rgb(15 23 42 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-teal-600{--tw-gradient-from: #0d9488 var(--tw-gradient-from-position);--tw-gradient-to: rgb(13 148 136 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-white{--tw-gradient-from: #fff var(--tw-gradient-from-position);--tw-gradient-to: rgb(255 255 255 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-yellow-500{--tw-gradient-from: #eab308 var(--tw-gradient-from-position);--tw-gradient-to: rgb(234 179 8 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.via-purple-900\/20{--tw-gradient-to: rgb(88 28 135 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), rgb(88 28 135 / .2) var(--tw-gradient-via-position), var(--tw-gradient-to)}.to-amber-600{--tw-gradient-to: #d97706 var(--tw-gradient-to-position)}.to-blue-700{--tw-gradient-to: #1d4ed8 var(--tw-gradient-to-position)}.to-cyan-600{--tw-gradient-to: #0891b2 var(--tw-gradient-to-position)}.to-emerald-500{--tw-gradient-to: #10b981 var(--tw-gradient-to-position)}.to-emerald-600{--tw-gradient-to: #059669 var(--tw-gradient-to-position)}.to-emerald-900\/30{--tw-gradient-to: rgb(6 78 59 / .3) var(--tw-gradient-to-position)}.to-gray-300{--tw-gradient-to: #d1d5db var(--tw-gradient-to-position)}.to-gray-800{--tw-gradient-to: #1f2937 var(--tw-gradient-to-position)}.to-green-600{--tw-gradient-to: #16a34a var(--tw-gradient-to-position)}.to-indigo-400{--tw-gradient-to: #818cf8 var(--tw-gradient-to-position)}.to-indigo-500{--tw-gradient-to: #6366f1 var(--tw-gradient-to-position)}.to-indigo-600{--tw-gradient-to: #4f46e5 var(--tw-gradient-to-position)}.to-orange-500{--tw-gradient-to: #f97316 var(--tw-gradient-to-position)}.to-pink-600{--tw-gradient-to: #db2777 var(--tw-gradient-to-position)}.to-purple-500{--tw-gradient-to: #a855f7 var(--tw-gradient-to-position)}.to-purple-600\/20{--tw-gradient-to: rgb(147 51 234 / .2) var(--tw-gradient-to-position)}.to-rose-500{--tw-gradient-to: #f43f5e var(--tw-gradient-to-position)}.to-rose-600{--tw-gradient-to: #e11d48 var(--tw-gradient-to-position)}.to-slate-900{--tw-gradient-to: #0f172a var(--tw-gradient-to-position)}.to-teal-600{--tw-gradient-to: #0d9488 var(--tw-gradient-to-position)}.to-yellow-600\/30{--tw-gradient-to: rgb(202 138 4 / .3) var(--tw-gradient-to-position)}.bg-clip-text{-webkit-background-clip:text;background-clip:text}.object-cover{-o-object-fit:cover;object-fit:cover}.p-0{padding:0}.p-0\.5{padding:.125rem}.p-1{padding:.25rem}.p-1\.5{padding:.375rem}.p-12{padding:3rem}.p-2{padding:.5rem}.p-3{padding:.75rem}.p-4{padding:1rem}.p-5{padding:1.25rem}.p-6{padding:1.5rem}.p-8{padding:2rem}.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-2\.5{padding-left:.625rem;padding-right:.625rem}.px-3{padding-left:.75rem;padding-right:.75rem}.px-4{padding-left:1rem;padding-right:1rem}.px-5{padding-left:1.25rem;padding-right:1.25rem}.px-6{padding-left:1.5rem;padding-right:1.5rem}.px-8{padding-left:2rem;padding-right:2rem}.py-0{padding-top:0;padding-bottom:0}.py-0\.5{padding-top:.125rem;padding-bottom:.125rem}.py-1{padding-top:.25rem;padding-bottom:.25rem}.py-1\.5{padding-top:.375rem;padding-bottom:.375rem}.py-12{padding-top:3rem;padding-bottom:3rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.py-2\.5{padding-top:.625rem;padding-bottom:.625rem}.py-3{padding-top:.75rem;padding-bottom:.75rem}.py-4{padding-top:1rem;padding-bottom:1rem}.py-8{padding-top:2rem;padding-bottom:2rem}.\!pl-10{padding-left:2.5rem!important}.pb-1{padding-bottom:.25rem}.pb-2{padding-bottom:.5rem}.pb-4{padding-bottom:1rem}.pr-1{padding-right:.25rem}.pr-2{padding-right:.5rem}.pr-4{padding-right:1rem}.pr-8{padding-right:2rem}.pt-1{padding-top:.25rem}.pt-14{padding-top:3.5rem}.pt-2{padding-top:.5rem}.pt-3{padding-top:.75rem}.pt-4{padding-top:1rem}.text-left{text-align:left}.text-center{text-align:center}.text-right{text-align:right}.font-mono{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace}.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-5xl{font-size:3rem;line-height:1}.text-6xl{font-size:3.75rem;line-height:1}.text-\[10px\]{font-size:10px}.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-medium{font-weight:500}.font-normal{font-weight:400}.font-semibold{font-weight:600}.uppercase{text-transform:uppercase}.lowercase{text-transform:lowercase}.capitalize{text-transform:capitalize}.italic{font-style:italic}.leading-none{line-height:1}.leading-relaxed{line-height:1.625}.leading-tight{line-height:1.25}.tracking-wide{letter-spacing:.025em}.tracking-wider{letter-spacing:.05em}.tracking-widest{letter-spacing:.1em}.text-amber-200{--tw-text-opacity: 1;color:rgb(253 230 138 / var(--tw-text-opacity))}.text-amber-300{--tw-text-opacity: 1;color:rgb(252 211 77 / var(--tw-text-opacity))}.text-amber-400{--tw-text-opacity: 1;color:rgb(251 191 36 / var(--tw-text-opacity))}.text-amber-500{--tw-text-opacity: 1;color:rgb(245 158 11 / var(--tw-text-opacity))}.text-amber-500\/80{color:#f59e0bcc}.text-black{--tw-text-opacity: 1;color:rgb(0 0 0 / var(--tw-text-opacity))}.text-blue-100{--tw-text-opacity: 1;color:rgb(219 234 254 / var(--tw-text-opacity))}.text-blue-200{--tw-text-opacity: 1;color:rgb(191 219 254 / var(--tw-text-opacity))}.text-blue-300{--tw-text-opacity: 1;color:rgb(147 197 253 / var(--tw-text-opacity))}.text-blue-400{--tw-text-opacity: 1;color:rgb(96 165 250 / var(--tw-text-opacity))}.text-blue-600{--tw-text-opacity: 1;color:rgb(37 99 235 / var(--tw-text-opacity))}.text-cyan-400{--tw-text-opacity: 1;color:rgb(34 211 238 / var(--tw-text-opacity))}.text-emerald-400{--tw-text-opacity: 1;color:rgb(52 211 153 / var(--tw-text-opacity))}.text-emerald-950{--tw-text-opacity: 1;color:rgb(2 44 34 / var(--tw-text-opacity))}.text-gray-200{--tw-text-opacity: 1;color:rgb(229 231 235 / var(--tw-text-opacity))}.text-gray-300{--tw-text-opacity: 1;color:rgb(209 213 219 / var(--tw-text-opacity))}.text-gray-400{--tw-text-opacity: 1;color:rgb(156 163 175 / var(--tw-text-opacity))}.text-gray-500{--tw-text-opacity: 1;color:rgb(107 114 128 / var(--tw-text-opacity))}.text-gray-600{--tw-text-opacity: 1;color:rgb(75 85 99 / var(--tw-text-opacity))}.text-gray-800{--tw-text-opacity: 1;color:rgb(31 41 55 / var(--tw-text-opacity))}.text-green-300{--tw-text-opacity: 1;color:rgb(134 239 172 / var(--tw-text-opacity))}.text-green-400{--tw-text-opacity: 1;color:rgb(74 222 128 / var(--tw-text-opacity))}.text-green-900{--tw-text-opacity: 1;color:rgb(20 83 45 / var(--tw-text-opacity))}.text-indigo-200{--tw-text-opacity: 1;color:rgb(199 210 254 / var(--tw-text-opacity))}.text-indigo-400{--tw-text-opacity: 1;color:rgb(129 140 248 / var(--tw-text-opacity))}.text-orange-400{--tw-text-opacity: 1;color:rgb(251 146 60 / var(--tw-text-opacity))}.text-purple-300{--tw-text-opacity: 1;color:rgb(216 180 254 / var(--tw-text-opacity))}.text-purple-400{--tw-text-opacity: 1;color:rgb(192 132 252 / var(--tw-text-opacity))}.text-red-200{--tw-text-opacity: 1;color:rgb(254 202 202 / var(--tw-text-opacity))}.text-red-400{--tw-text-opacity: 1;color:rgb(248 113 113 / var(--tw-text-opacity))}.text-red-500{--tw-text-opacity: 1;color:rgb(239 68 68 / var(--tw-text-opacity))}.text-red-950{--tw-text-opacity: 1;color:rgb(69 10 10 / var(--tw-text-opacity))}.text-slate-400{--tw-text-opacity: 1;color:rgb(148 163 184 / var(--tw-text-opacity))}.text-slate-900{--tw-text-opacity: 1;color:rgb(15 23 42 / var(--tw-text-opacity))}.text-teal-300{--tw-text-opacity: 1;color:rgb(94 234 212 / var(--tw-text-opacity))}.text-teal-400{--tw-text-opacity: 1;color:rgb(45 212 191 / var(--tw-text-opacity))}.text-transparent{color:transparent}.text-white{--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity))}.text-yellow-400{--tw-text-opacity: 1;color:rgb(250 204 21 / var(--tw-text-opacity))}.text-yellow-500{--tw-text-opacity: 1;color:rgb(234 179 8 / var(--tw-text-opacity))}.text-yellow-900{--tw-text-opacity: 1;color:rgb(113 63 18 / var(--tw-text-opacity))}.underline{text-decoration-line:underline}.no-underline{text-decoration-line:none}.placeholder-gray-400::-moz-placeholder{--tw-placeholder-opacity: 1;color:rgb(156 163 175 / var(--tw-placeholder-opacity))}.placeholder-gray-400::placeholder{--tw-placeholder-opacity: 1;color:rgb(156 163 175 / var(--tw-placeholder-opacity))}.placeholder-gray-500::-moz-placeholder{--tw-placeholder-opacity: 1;color:rgb(107 114 128 / var(--tw-placeholder-opacity))}.placeholder-gray-500::placeholder{--tw-placeholder-opacity: 1;color:rgb(107 114 128 / var(--tw-placeholder-opacity))}.accent-purple-500{accent-color:#a855f7}.opacity-0{opacity:0}.opacity-10{opacity:.1}.opacity-100{opacity:1}.opacity-50{opacity:.5}.opacity-60{opacity:.6}.opacity-70{opacity:.7}.opacity-75{opacity:.75}.opacity-80{opacity:.8}.shadow{--tw-shadow: 0 1px 3px 0 rgb(0 0 0 / .1), 0 1px 2px -1px rgb(0 0 0 / .1);--tw-shadow-colored: 0 1px 3px 0 var(--tw-shadow-color), 0 1px 2px -1px 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-2xl{--tw-shadow: 0 25px 50px -12px rgb(0 0 0 / .25);--tw-shadow-colored: 0 25px 50px -12px 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-inner{--tw-shadow: inset 0 2px 4px 0 rgb(0 0 0 / .05);--tw-shadow-colored: inset 0 2px 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-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)}.shadow-sm{--tw-shadow: 0 1px 2px 0 rgb(0 0 0 / .05);--tw-shadow-colored: 0 1px 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-xl{--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)}.shadow-blue-500\/10{--tw-shadow-color: rgb(59 130 246 / .1);--tw-shadow: var(--tw-shadow-colored)}.shadow-blue-500\/20{--tw-shadow-color: rgb(59 130 246 / .2);--tw-shadow: var(--tw-shadow-colored)}.shadow-blue-500\/25{--tw-shadow-color: rgb(59 130 246 / .25);--tw-shadow: var(--tw-shadow-colored)}.shadow-emerald-500\/25{--tw-shadow-color: rgb(16 185 129 / .25);--tw-shadow: var(--tw-shadow-colored)}.shadow-emerald-500\/30{--tw-shadow-color: rgb(16 185 129 / .3);--tw-shadow: var(--tw-shadow-colored)}.shadow-fuchsia-500\/25{--tw-shadow-color: rgb(217 70 239 / .25);--tw-shadow: var(--tw-shadow-colored)}.shadow-gray-500\/25{--tw-shadow-color: rgb(107 114 128 / .25);--tw-shadow: var(--tw-shadow-colored)}.shadow-green-500\/25{--tw-shadow-color: rgb(34 197 94 / .25);--tw-shadow: var(--tw-shadow-colored)}.shadow-green-600\/20{--tw-shadow-color: rgb(22 163 74 / .2);--tw-shadow: var(--tw-shadow-colored)}.shadow-orange-500\/25{--tw-shadow-color: rgb(249 115 22 / .25);--tw-shadow: var(--tw-shadow-colored)}.shadow-pink-500\/20{--tw-shadow-color: rgb(236 72 153 / .2);--tw-shadow: var(--tw-shadow-colored)}.shadow-pink-500\/25{--tw-shadow-color: rgb(236 72 153 / .25);--tw-shadow: var(--tw-shadow-colored)}.shadow-purple-500\/25{--tw-shadow-color: rgb(168 85 247 / .25);--tw-shadow: var(--tw-shadow-colored)}.shadow-purple-900\/20{--tw-shadow-color: rgb(88 28 135 / .2);--tw-shadow: var(--tw-shadow-colored)}.shadow-purple-900\/30{--tw-shadow-color: rgb(88 28 135 / .3);--tw-shadow: var(--tw-shadow-colored)}.shadow-red-500\/25{--tw-shadow-color: rgb(239 68 68 / .25);--tw-shadow: var(--tw-shadow-colored)}.shadow-teal-500\/25{--tw-shadow-color: rgb(20 184 166 / .25);--tw-shadow: var(--tw-shadow-colored)}.shadow-yellow-500\/10{--tw-shadow-color: rgb(234 179 8 / .1);--tw-shadow: var(--tw-shadow-colored)}.shadow-yellow-500\/25{--tw-shadow-color: rgb(234 179 8 / .25);--tw-shadow: var(--tw-shadow-colored)}.outline-none{outline:2px solid transparent;outline-offset:2px}.outline{outline-style:solid}.ring-1{--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(1px + 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-blue-500\/30{--tw-ring-color: rgb(59 130 246 / .3)}.ring-red-500\/50{--tw-ring-color: rgb(239 68 68 / .5)}.drop-shadow{--tw-drop-shadow: drop-shadow(0 1px 2px rgb(0 0 0 / .1)) drop-shadow(0 1px 1px 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-\[0_0_8px_rgba\(102\,126\,234\,0\.4\)\]{--tw-drop-shadow: drop-shadow(0 0 8px rgba(102,126,234,.4));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)}.backdrop-blur{--tw-backdrop-blur: blur(8px);-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)}.backdrop-blur-sm{--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)}.backdrop-blur-xl{--tw-backdrop-blur: blur(24px);-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)}.transition-\[margin\]{transition-property:margin;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-200{transition-duration:.2s}.duration-300{transition-duration:.3s}.duration-500{transition-duration:.5s}.ease-in-out{transition-timing-function:cubic-bezier(.4,0,.2,1)}.ease-out{transition-timing-function:cubic-bezier(0,0,.2,1)}.app-container{width:100%;min-height:100vh;padding:1rem}@media(min-width:768px){.app-container{padding:2rem}}.flex-mobile-col{display:flex;flex-direction:column;gap:1rem}@media(min-width:768px){.flex-mobile-col{flex-direction:row;gap:1.5rem}}.center-content{display:flex;align-items:center;justify-content:center}.stack{display:flex;flex-direction:column;gap:1rem}.grid-auto{display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}@media(max-width:768px){.grid-auto{grid-template-columns:1fr}}.first\:mt-0:first-child{margin-top:0}.hover\:scale-110:hover{--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))}.hover\:scale-\[1\.02\]:hover{--tw-scale-x: 1.02;--tw-scale-y: 1.02;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\:border-blue-500\/30:hover{border-color:#3b82f64d}.hover\:border-blue-500\/50:hover{border-color:#3b82f680}.hover\:border-orange-500\/30:hover{border-color:#f973164d}.hover\:border-slate-500:hover{--tw-border-opacity: 1;border-color:rgb(100 116 139 / var(--tw-border-opacity))}.hover\:border-slate-500\/50:hover{border-color:#64748b80}.hover\:border-slate-600:hover{--tw-border-opacity: 1;border-color:rgb(71 85 105 / var(--tw-border-opacity))}.hover\:border-yellow-500\/30:hover{border-color:#eab3084d}.hover\:bg-blue-500:hover{--tw-bg-opacity: 1;background-color:rgb(59 130 246 / var(--tw-bg-opacity))}.hover\:bg-blue-600\/30:hover{background-color:#2563eb4d}.hover\:bg-emerald-400:hover{--tw-bg-opacity: 1;background-color:rgb(52 211 153 / var(--tw-bg-opacity))}.hover\:bg-emerald-500:hover{--tw-bg-opacity: 1;background-color:rgb(16 185 129 / var(--tw-bg-opacity))}.hover\:bg-gray-600:hover{--tw-bg-opacity: 1;background-color:rgb(75 85 99 / var(--tw-bg-opacity))}.hover\:bg-green-500:hover{--tw-bg-opacity: 1;background-color:rgb(34 197 94 / var(--tw-bg-opacity))}.hover\:bg-green-600\/30:hover{background-color:#16a34a4d}.hover\:bg-orange-500:hover{--tw-bg-opacity: 1;background-color:rgb(249 115 22 / var(--tw-bg-opacity))}.hover\:bg-purple-500:hover{--tw-bg-opacity: 1;background-color:rgb(168 85 247 / var(--tw-bg-opacity))}.hover\:bg-purple-600\/30:hover{background-color:#9333ea4d}.hover\:bg-red-400:hover{--tw-bg-opacity: 1;background-color:rgb(248 113 113 / var(--tw-bg-opacity))}.hover\:bg-red-500:hover{--tw-bg-opacity: 1;background-color:rgb(239 68 68 / var(--tw-bg-opacity))}.hover\:bg-red-500\/20:hover{background-color:#ef444433}.hover\:bg-red-500\/30:hover{background-color:#ef44444d}.hover\:bg-red-600:hover{--tw-bg-opacity: 1;background-color:rgb(220 38 38 / var(--tw-bg-opacity))}.hover\:bg-red-600\/30:hover{background-color:#dc26264d}.hover\:bg-red-600\/40:hover{background-color:#dc262666}.hover\:bg-red-900\/20:hover{background-color:#7f1d1d33}.hover\:bg-slate-400:hover{--tw-bg-opacity: 1;background-color:rgb(148 163 184 / var(--tw-bg-opacity))}.hover\:bg-slate-500:hover{--tw-bg-opacity: 1;background-color:rgb(100 116 139 / var(--tw-bg-opacity))}.hover\:bg-slate-600:hover{--tw-bg-opacity: 1;background-color:rgb(71 85 105 / var(--tw-bg-opacity))}.hover\:bg-slate-600\/50:hover{background-color:#47556980}.hover\:bg-slate-700:hover{--tw-bg-opacity: 1;background-color:rgb(51 65 85 / var(--tw-bg-opacity))}.hover\:bg-slate-700\/30:hover{background-color:#3341554d}.hover\:bg-slate-700\/50:hover{background-color:#33415580}.hover\:bg-slate-700\/70:hover{background-color:#334155b3}.hover\:bg-slate-800:hover{--tw-bg-opacity: 1;background-color:rgb(30 41 59 / var(--tw-bg-opacity))}.hover\:bg-slate-900\/70:hover{background-color:#0f172ab3}.hover\:bg-white\/10:hover{background-color:#ffffff1a}.hover\:bg-white\/5:hover{background-color:#ffffff0d}.hover\:bg-yellow-600\/30:hover{background-color:#ca8a044d}.hover\:from-amber-400:hover{--tw-gradient-from: #fbbf24 var(--tw-gradient-from-position);--tw-gradient-to: rgb(251 191 36 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.hover\:from-blue-500:hover{--tw-gradient-from: #3b82f6 var(--tw-gradient-from-position);--tw-gradient-to: rgb(59 130 246 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.hover\:from-emerald-500:hover{--tw-gradient-from: #10b981 var(--tw-gradient-from-position);--tw-gradient-to: rgb(16 185 129 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.hover\:from-green-500:hover{--tw-gradient-from: #22c55e var(--tw-gradient-from-position);--tw-gradient-to: rgb(34 197 94 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.hover\:from-green-600:hover{--tw-gradient-from: #16a34a var(--tw-gradient-from-position);--tw-gradient-to: rgb(22 163 74 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.hover\:from-indigo-600\/30:hover{--tw-gradient-from: rgb(79 70 229 / .3) var(--tw-gradient-from-position);--tw-gradient-to: rgb(79 70 229 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.hover\:from-pink-500:hover{--tw-gradient-from: #ec4899 var(--tw-gradient-from-position);--tw-gradient-to: rgb(236 72 153 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.hover\:from-purple-500:hover{--tw-gradient-from: #a855f7 var(--tw-gradient-from-position);--tw-gradient-to: rgb(168 85 247 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.hover\:to-blue-600:hover{--tw-gradient-to: #2563eb var(--tw-gradient-to-position)}.hover\:to-emerald-500:hover{--tw-gradient-to: #10b981 var(--tw-gradient-to-position)}.hover\:to-emerald-700:hover{--tw-gradient-to: #047857 var(--tw-gradient-to-position)}.hover\:to-indigo-500:hover{--tw-gradient-to: #6366f1 var(--tw-gradient-to-position)}.hover\:to-orange-400:hover{--tw-gradient-to: #fb923c var(--tw-gradient-to-position)}.hover\:to-purple-600\/30:hover{--tw-gradient-to: rgb(147 51 234 / .3) var(--tw-gradient-to-position)}.hover\:to-rose-500:hover{--tw-gradient-to: #f43f5e var(--tw-gradient-to-position)}.hover\:to-teal-500:hover{--tw-gradient-to: #14b8a6 var(--tw-gradient-to-position)}.hover\:text-amber-400:hover{--tw-text-opacity: 1;color:rgb(251 191 36 / var(--tw-text-opacity))}.hover\:text-blue-300:hover{--tw-text-opacity: 1;color:rgb(147 197 253 / var(--tw-text-opacity))}.hover\:text-gray-200:hover{--tw-text-opacity: 1;color:rgb(229 231 235 / var(--tw-text-opacity))}.hover\:text-purple-300:hover{--tw-text-opacity: 1;color:rgb(216 180 254 / var(--tw-text-opacity))}.hover\:text-purple-400:hover{--tw-text-opacity: 1;color:rgb(192 132 252 / var(--tw-text-opacity))}.hover\:text-red-300:hover{--tw-text-opacity: 1;color:rgb(252 165 165 / var(--tw-text-opacity))}.hover\:text-white:hover{--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity))}.hover\:text-yellow-400:hover{--tw-text-opacity: 1;color:rgb(250 204 21 / var(--tw-text-opacity))}.hover\:text-yellow-400\/50:hover{color:#facc1580}.hover\:underline:hover{text-decoration-line:underline}.hover\:shadow-2xl:hover{--tw-shadow: 0 25px 50px -12px rgb(0 0 0 / .25);--tw-shadow-colored: 0 25px 50px -12px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.hover\:shadow-md:hover{--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)}.hover\:shadow-xl:hover{--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)}.hover\:brightness-110:hover{--tw-brightness: brightness(1.1);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)}.focus\:border-green-500:focus{--tw-border-opacity: 1;border-color:rgb(34 197 94 / var(--tw-border-opacity))}.focus\:border-purple-500:focus{--tw-border-opacity: 1;border-color:rgb(168 85 247 / var(--tw-border-opacity))}.focus\:border-transparent:focus{border-color:transparent}.focus\:outline-none:focus{outline:2px solid transparent;outline-offset:2px}.focus\:ring-1:focus{--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(1px + 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)}.focus\:ring-2:focus{--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)}.focus\:ring-blue-500:focus{--tw-ring-opacity: 1;--tw-ring-color: rgb(59 130 246 / var(--tw-ring-opacity))}.focus\:ring-purple-500:focus{--tw-ring-opacity: 1;--tw-ring-color: rgb(168 85 247 / var(--tw-ring-opacity))}.focus\:ring-purple-500\/50:focus{--tw-ring-color: rgb(168 85 247 / .5)}.focus\:ring-offset-slate-900:focus{--tw-ring-offset-color: #0f172a}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.disabled\:bg-gray-800:disabled{--tw-bg-opacity: 1;background-color:rgb(31 41 55 / var(--tw-bg-opacity))}.disabled\:text-gray-500:disabled{--tw-text-opacity: 1;color:rgb(107 114 128 / var(--tw-text-opacity))}.disabled\:opacity-30:disabled{opacity:.3}.disabled\:opacity-40:disabled{opacity:.4}.disabled\:opacity-50:disabled{opacity:.5}.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\:text-blue-400{--tw-text-opacity: 1;color:rgb(96 165 250 / var(--tw-text-opacity))}.group:hover .group-hover\:text-white{--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity))}.group:hover .group-hover\:opacity-100{opacity:1}.group:hover .group-hover\:opacity-20{opacity:.2}@media(min-width:640px){.sm\:block{display:block}.sm\:inline{display:inline}.sm\:hidden{display:none}.sm\:w-64{width:16rem}.sm\:w-auto{width:auto}.sm\:max-w-none{max-width:none}.sm\:flex-none{flex:none}.sm\:flex-row{flex-direction:row}.sm\:items-center{align-items:center}.sm\:justify-start{justify-content:flex-start}.sm\:p-0{padding:0}.sm\:px-4{padding-left:1rem;padding-right:1rem}}@media(min-width:768px){.md\:mb-2{margin-bottom:.5rem}.md\:mb-6{margin-bottom:1.5rem}.md\:block{display:block}.md\:h-10{height:2.5rem}.md\:h-14{height:3.5rem}.md\:h-16{height:4rem}.md\:h-\[min\(calc\(100vw-6rem\)\,calc\(100vh-14rem\)\)\]{height:min(calc(100vw - 6rem),calc(100vh - 14rem))}.md\:max-h-\[600px\]{max-height:600px}.md\:w-10{width:2.5rem}.md\:w-14{width:3.5rem}.md\:w-16{width:4rem}.md\:w-7{width:1.75rem}.md\:min-w-\[180px\]{min-width:180px}.md\:max-w-\[400px\]{max-width:400px}.md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.md\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.md\:flex-row{flex-direction:row}.md\:gap-3{gap:.75rem}.md\:gap-4{gap:1rem}.md\:gap-6{gap:1.5rem}.md\:p-4{padding:1rem}.md\:p-5{padding:1.25rem}.md\:p-6{padding:1.5rem}.md\:p-8{padding:2rem}.md\:px-4{padding-left:1rem;padding-right:1rem}.md\:px-8{padding-left:2rem;padding-right:2rem}.md\:py-16{padding-top:4rem;padding-bottom:4rem}.md\:py-2{padding-top:.5rem;padding-bottom:.5rem}.md\:py-3{padding-top:.75rem;padding-bottom:.75rem}.md\:py-4{padding-top:1rem;padding-bottom:1rem}.md\:py-5{padding-top:1.25rem;padding-bottom:1.25rem}.md\:py-6{padding-top:1.5rem;padding-bottom:1.5rem}.md\:pb-2{padding-bottom:.5rem}.md\:pt-2{padding-top:.5rem}.md\:text-2xl{font-size:1.5rem;line-height:2rem}.md\:text-3xl{font-size:1.875rem;line-height:2.25rem}.md\:text-6xl{font-size:3.75rem;line-height:1}.md\:text-base{font-size:1rem;line-height:1.5rem}.md\:text-lg{font-size:1.125rem;line-height:1.75rem}.md\:text-sm{font-size:.875rem;line-height:1.25rem}.md\:text-xl{font-size:1.25rem;line-height:1.75rem}.md\:text-xs{font-size:.75rem;line-height:1rem}}@media(min-width:1024px){.lg\:mb-6{margin-bottom:1.5rem}.lg\:ml-2{margin-left:.5rem}.lg\:ml-\[200px\]{margin-left:200px}.lg\:flex{display:flex}.lg\:hidden{display:none}.lg\:h-40{height:10rem}.lg\:h-64{height:16rem}.lg\:h-80{height:20rem}.lg\:w-7{width:1.75rem}.lg\:w-80{width:20rem}.lg\:w-96{width:24rem}.lg\:w-\[200px\]{width:200px}.lg\:w-\[400px\]{width:400px}.lg\:w-\[500px\]{width:500px}.lg\:w-auto{width:auto}.lg\:max-w-xl{max-width:36rem}.lg\:flex-1{flex:1 1 0%}.lg\:flex-none{flex:none}.lg\:translate-x-0{--tw-translate-x: 0px;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))}.lg\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.lg\:flex-row{flex-direction:row}.lg\:items-center{align-items:center}.lg\:gap-6{gap:1.5rem}.lg\:p-6{padding:1.5rem}.lg\:pt-0{padding-top:0}}@media(min-width:1280px){.xl\:w-96{width:24rem}.xl\:w-\[450px\]{width:450px}.xl\:w-\[560px\]{width:560px}}.custom-board-wrapper{position:relative;width:100%;height:100%;max-width:100%;aspect-ratio:1;-webkit-user-select:none;-moz-user-select:none;user-select:none}.custom-board{display:grid;grid-template-columns:repeat(8,1fr);grid-template-rows:repeat(8,1fr);width:100%;height:100%;min-width:0;border-radius:4px;overflow:hidden;box-shadow:0 5px 15px #00000080;position:relative}.square{position:relative;width:100%;height:100%;display:flex;justify-content:center;align-items:center}.square.light{background-color:#f0d9b5}.square.dark{background-color:#b58863}.square.selected{background-color:#ffff0080!important}.piece{width:90%;height:90%;cursor:grab;z-index:2;transition:transform .1s}.piece:active{cursor:grabbing}.move-marker{width:30%;height:30%;background-color:#0003;border-radius:50%;z-index:1}.square.possible-move.dark .move-marker{background-color:#0000004d}.square.possible-move:has(.piece):after{content:"";position:absolute;width:90%;height:90%;border-radius:50%;border:4px solid rgba(0,0,0,.2);box-sizing:border-box}.rank-label{position:absolute;top:2px;left:2px;font-size:10px;font-weight:700;color:inherit;opacity:.8}.file-label{position:absolute;bottom:2px;right:2px;font-size:10px;font-weight:700;color:inherit;opacity:.8}.square.hint-square{box-shadow:inset 0 0 0 3px #ffd700cc;animation:pulse-hint 1s ease-in-out infinite}@keyframes pulse-hint{0%,to{box-shadow:inset 0 0 0 3px #ffd700cc}50%{box-shadow:inset 0 0 0 3px gold}}.rank-label{position:absolute;top:2px;left:2px;font-size:14px;font-weight:700;color:inherit;opacity:1}.file-label{position:absolute;bottom:2px;right:2px;font-size:14px;font-weight:700;color:inherit;opacity:1}.square.light .rank-label,.square.light .file-label{color:#779556}.square.dark .rank-label,.square.dark .file-label{color:#ebecd0}@media(max-width:768px){.rank-label,.file-label{font-size:12px}}.game-over-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:#000000b3;display:flex;flex-direction:column;justify-content:center;align-items:center;color:#fff;z-index:10}.custom-board{position:relative}.game-history{background:linear-gradient(135deg,#1a1a2e,#16213e);border-radius:12px;padding:20px;color:#fff;box-shadow:0 8px 16px #0000004d;max-height:600px;overflow-y:auto}.game-history h2{margin:0 0 20px;font-size:20px;text-align:center;color:#64ffda;text-transform:uppercase;letter-spacing:1.5px}.vsaihistory>.game-history{margin:0;padding:0;max-height:380px;background-image:none;padding:1rem}.empty-state{text-align:center;padding:40px 20px;color:#a8dadc}.empty-state p{margin:8px 0}.empty-state .hint{font-size:14px;opacity:.7}.games-list{display:flex;flex-direction:column;gap:12px}.game-card{background:#ffffff0d;border-radius:8px;overflow:hidden;transition:all .3s ease}.game-card:hover{background:#ffffff14}.game-header{padding:12px;cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:8px}.game-info{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.result-badge{padding:4px 12px;border-radius:4px;font-size:13px;font-weight:600;text-transform:uppercase}.result-badge.win{background:linear-gradient(135deg,#43e97b,#38f9d7);color:#1a1a2e}.result-badge.loss{background:linear-gradient(135deg,#ff6b6b,#ee5a6f);color:#fff}.result-badge.draw{background:linear-gradient(135deg,#ffa726,#fb8c00);color:#fff}.opponent{font-size:14px;color:#a8dadc}.game-date{font-size:12px;color:#888;white-space:nowrap}.game-details{padding:12px;border-top:1px solid rgba(255,255,255,.1);background:#0003}.details-row{display:flex;justify-content:space-between;padding:6px 0;font-size:14px}.details-row span:first-child{color:#a8dadc;font-weight:600}.details-row span:last-child{color:#64ffda}.move-list{margin:12px 0;padding:12px;background:#ffffff08;border-radius:6px;min-height:150px;max-height:150px;overflow-y:auto;font-family:Courier New,monospace;font-size:13px;line-height:1.8}.move-item{margin-right:8px;color:#64ffda}.game-actions{display:flex;gap:8px;margin-top:12px}.action-btn{flex:1;padding:8px 12px;border:none;border-radius:6px;font-size:13px;font-weight:600;cursor:pointer;transition:all .3s ease}.action-btn.view{background:linear-gradient(135deg,#f093fb,#f5576c);color:#fff}.action-btn.view:hover{transform:translateY(-2px);box-shadow:0 4px 8px #f5576c66}.action-btn.analyze{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.action-btn.analyze:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 8px #667eea66}.action-btn.analyze:disabled{opacity:.6;cursor:not-allowed}.action-btn.download{background:linear-gradient(135deg,#43e97b,#38f9d7);color:#1a1a2e}.action-btn.download:hover{transform:translateY(-2px);box-shadow:0 4px 8px #43e97b66}.action-btn.delete{background:linear-gradient(135deg,#ff6b6b,#ee5a6f);color:#fff}.action-btn.delete:hover{transform:translateY(-2px);box-shadow:0 4px 8px #ff6b6b66}.analysis-results{margin-top:16px;padding:16px;background:#64ffda1a;border-radius:8px;border:1px solid rgba(100,255,218,.2)}.analysis-results h4{margin:0 0 12px;color:#64ffda;font-size:16px}.analysis-summary{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.analysis-summary .stat{display:flex;flex-direction:column;gap:4px;padding:10px;background:#0000004d;border-radius:6px}.analysis-summary .stat span:first-child{font-size:12px;color:#a8dadc;font-weight:600}.analysis-summary .stat .value{font-size:18px;color:#64ffda;font-weight:700}.game-history::-webkit-scrollbar,.move-list::-webkit-scrollbar{width:6px}.game-history::-webkit-scrollbar-track,.move-list::-webkit-scrollbar-track{background:#ffffff0d;border-radius:3px}.game-history::-webkit-scrollbar-thumb,.move-list::-webkit-scrollbar-thumb{background:#64ffda4d;border-radius:3px}.game-history::-webkit-scrollbar-thumb:hover,.move-list::-webkit-scrollbar-thumb:hover{background:#64ffda80}.replay-analysis{background:linear-gradient(135deg,#1a1a2e,#16213e);border-radius:12px;padding:16px;margin-top:12px;border:1px solid rgba(255,255,255,.1);box-shadow:0 4px 12px #0000004d}.analysis-header h4{margin:0 0 12px;font-size:14px;font-weight:600;color:#e0e0e0;display:flex;align-items:center;gap:6px}.no-analysis{text-align:center;padding:20px;color:#999;font-size:13px}.move-info{display:flex;align-items:center;gap:12px}.move-number{font-size:12px;color:#999;font-weight:500}.move-san{font-size:18px;font-weight:700;color:#fff;font-family:Courier New,monospace}.classification-badge{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:20px;font-size:11px;font-weight:700;color:#fff;margin-bottom:12px;text-transform:uppercase;letter-spacing:.5px;box-shadow:0 2px 8px #0003}.classification-icon{font-size:14px}.classification-text{font-size:10px}.evaluation-info{background:#ffffff0d;border-radius:8px;padding:10px;margin-bottom:12px}.eval-row{display:flex;justify-content:space-between;align-items:center;padding:4px 0}.eval-label{font-size:12px;color:#999;font-weight:500}.eval-value{font-size:14px;font-weight:700;color:#fff;font-family:Courier New,monospace}.eval-change{font-size:14px;font-weight:700;font-family:Courier New,monospace}.eval-change.positive{color:#66bb6a}.eval-change.negative{color:#ef5350}.best-move-info{background:linear-gradient(135deg,#26a69a1a,#26a69a0d);border:1px solid rgba(38,166,154,.3);border-radius:8px;padding:10px}.best-move-label{font-size:11px;color:#26a69a;font-weight:600;margin-bottom:4px;text-transform:uppercase;letter-spacing:.5px}.best-move-value{font-size:16px;font-weight:700;color:#fff;font-family:Courier New,monospace;display:flex;align-items:center;gap:8px}.best-eval{font-size:13px;color:#26a69a;font-weight:600}.evaluation-graph{background:linear-gradient(135deg,#1a1a2e,#16213e);border-radius:12px;padding:16px;margin-top:12px;border:1px solid rgba(255,255,255,.1);box-shadow:0 4px 12px #0000004d}.graph-header h4{margin:0 0 12px;font-size:14px;font-weight:600;color:#e0e0e0;display:flex;align-items:center;gap:6px}.evaluation-graph svg{border-radius:8px;overflow:hidden;display:block}.graph-labels{display:flex;justify-content:space-between;align-items:center;margin-top:8px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.label-white{color:#fff}.label-center{color:#999}.label-black{color:#666}.eval-bar-container{display:flex;flex-direction:column;align-items:center;height:100%}.eval-bar{position:relative;width:28px;height:100%;border-radius:4px;overflow:hidden;box-shadow:0 2px 8px #0000004d,inset 0 1px 2px #ffffff1a;border:1px solid rgba(255,255,255,.1);background:#1a1a1a}.eval-bar-section{position:absolute;left:0;right:0;transition:height .3s cubic-bezier(.4,0,.2,1)}.eval-bar-white{bottom:0;background:linear-gradient(to right,#e8e8e8,#fff,#e8e8e8);box-shadow:inset 0 1px 2px #0000001a}.eval-bar-black{top:0;background:linear-gradient(to right,#2a2a2a,#3a3a3a,#2a2a2a);box-shadow:inset 0 -1px 2px #0000004d}.eval-bar-text{position:absolute;left:50%;transform:translate(-50%);font-size:10px;font-weight:700;font-family:Inter,Segoe UI,sans-serif;letter-spacing:-.5px;text-shadow:0 1px 2px rgba(0,0,0,.5);white-space:nowrap;z-index:10;transition:top .3s cubic-bezier(.4,0,.2,1)}.eval-bar-text.on-white{color:#1a1a1a;text-shadow:0 1px 1px rgba(255,255,255,.3)}.eval-bar-text.on-black{color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.8)}@media(max-width:768px){.eval-bar{width:20px}.eval-bar-text{font-size:9px}}.opening-importer-overlay{position:fixed;inset:0;background:#000000b3;display:flex;justify-content:center;align-items:center;z-index:1000}.opening-importer-modal{background:#2b2b2b;border-radius:12px;padding:30px;max-width:600px;width:90%;max-height:85vh;overflow-y:auto;box-shadow:0 10px 40px #00000080}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:25px}.modal-header h2{margin:0;color:#fff;font-size:24px}.close-btn{background:none;border:none;color:#999;font-size:28px;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s}.close-btn:hover{background:#ffffff1a;color:#fff}.importer-step{color:#fff}.importer-step h3{margin-bottom:20px;color:#e0e0e0}.step-description{color:#999;margin-bottom:20px;font-size:14px}.search-opening-input{width:100%;padding:14px 18px;background:#1a1a1a;border:2px solid #444;border-radius:8px;color:#fff;font-size:16px;transition:border-color .2s;margin-bottom:15px}.search-opening-input:focus{outline:none;border-color:#4a9eff}.search-opening-input::-moz-placeholder{color:#666}.search-opening-input::placeholder{color:#666}.search-results{max-height:300px;overflow-y:auto;margin-bottom:20px;border:2px solid #444;border-radius:8px;background:#1a1a1a}.search-result-item{width:100%;padding:12px 16px;background:transparent;border:none;border-bottom:1px solid #333;color:#fff;cursor:pointer;transition:all .2s;text-align:left;display:flex;justify-content:space-between;align-items:center}.search-result-item:last-child{border-bottom:none}.search-result-item:hover{background:#2a2a2a;padding-left:20px}.result-name{font-size:15px;font-weight:500}.result-meta{display:flex;gap:12px;align-items:center}.result-eco{background:#333;padding:3px 8px;border-radius:4px;font-size:12px;color:#999;font-family:monospace}.result-color{font-size:20px}.no-search-results{text-align:center;padding:30px 20px;color:#999}.no-search-results p{margin:8px 0}.hint-text{font-size:14px;color:#666}.or-divider{display:flex;align-items:center;text-align:center;margin:25px 0;color:#666}.or-divider:before,.or-divider:after{content:"";flex:1;border-bottom:1px solid #444}.or-divider:not(:empty):before{margin-right:15px}.or-divider:not(:empty):after{margin-left:15px}.or-divider span{font-size:14px;text-transform:uppercase;letter-spacing:1px}.manual-browse-btn{width:100%;padding:14px 20px;background:#333;border:2px solid #444;border-radius:8px;color:#fff;font-size:16px;cursor:pointer;transition:all .2s}.manual-browse-btn:hover{background:#3a3a3a;border-color:#4a9eff;transform:translateY(-2px)}.color-buttons{display:grid;grid-template-columns:1fr 1fr;gap:15px;margin-top:20px}.color-btn{padding:30px 20px;border:2px solid #444;border-radius:8px;background:#333;color:#fff;font-size:18px;cursor:pointer;transition:all .3s;display:flex;flex-direction:column;align-items:center;gap:10px}.color-btn:hover{border-color:#4a9eff;background:#3a3a3a;transform:translateY(-2px)}.piece-icon{font-size:48px}.move-buttons{display:flex;flex-direction:column;gap:12px;margin-top:20px}.move-btn{padding:15px 20px;border:2px solid #444;border-radius:8px;background:#333;color:#fff;font-size:16px;cursor:pointer;transition:all .2s;text-align:left}.move-btn:hover{border-color:#4a9eff;background:#3a3a3a;transform:translate(5px)}.importer-loading{text-align:center;padding:40px 20px}.spinner{border:4px solid #444;border-top:4px solid #4a9eff;border-radius:50%;width:50px;height:50px;animation:spin 1s linear infinite;margin:0 auto 20px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.importer-loading h3{color:#fff;margin-bottom:10px}.importer-loading p{color:#999}.error-message{background:#ff3b3026;border:2px solid #ff3b30;border-radius:8px;padding:12px 16px;color:#ff6b6b;margin-bottom:20px}.success-message{background:#34c75926;border:2px solid #34c759;border-radius:8px;padding:12px 16px;color:#5dd879;margin-bottom:20px}.opening-preview{margin-bottom:25px}.form-group{margin-bottom:20px}.form-group label{display:block;color:#ccc;margin-bottom:8px;font-size:14px;font-weight:500}.form-group input{width:100%;padding:12px 16px;background:#1a1a1a;border:2px solid #444;border-radius:8px;color:#fff;font-size:16px;transition:border-color .2s}.form-group input:focus{outline:none;border-color:#4a9eff}.move-sequence{margin:25px 0}.move-sequence h4{color:#ccc;margin-bottom:12px;font-size:14px}.moves-display{background:#1a1a1a;border:2px solid #444;border-radius:8px;padding:15px;display:flex;flex-wrap:wrap;gap:8px;max-height:150px;overflow-y:auto}.move-chip{background:#2d2d2d;color:#aaa;padding:4px 10px;border-radius:4px;font-size:13px;font-family:Courier New,monospace}.action-buttons{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:25px}.cancel-btn,.save-btn{padding:12px 24px;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s}.cancel-btn{background:#444;color:#fff}.cancel-btn:hover{background:#555}.save-btn{background:#4a9eff;color:#fff}.save-btn:hover{background:#3d8fe8;transform:translateY(-2px);box-shadow:0 4px 12px #4a9eff4d}.custom-moves-toggle{width:100%;padding:12px 16px;background:#333;border:2px solid #444;border-radius:8px;color:#fff;font-size:14px;cursor:pointer;transition:all .2s;text-align:left;font-weight:500}.custom-moves-toggle:hover{background:#3a3a3a;border-color:#4a9eff}.custom-moves-input{margin-top:15px;padding:15px;background:#1a1a1a;border:2px solid #444;border-radius:8px}.custom-moves-hint{color:#999;font-size:13px;margin-bottom:12px;line-height:1.5}.custom-moves-hint strong{color:#4a9eff}.moves-textarea{width:100%;padding:12px;background:#2b2b2b;border:2px solid #444;border-radius:6px;color:#fff;font-size:14px;font-family:Courier New,monospace;resize:vertical;transition:border-color .2s}.moves-textarea:focus{outline:none;border-color:#4a9eff}.moves-textarea::-moz-placeholder{color:#666}.moves-textarea::placeholder{color:#666}.import-custom-btn{width:100%;margin-top:12px;padding:12px 20px;background:#4a9eff;border:none;border-radius:8px;color:#fff;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s}.import-custom-btn:hover:not(:disabled){background:#3d8fe8;transform:translateY(-2px);box-shadow:0 4px 12px #4a9eff4d}.import-custom-btn:disabled{background:#444;color:#666;cursor:not-allowed}.puzzle-controls{display:flex;flex-direction:column;gap:12px;padding:16px;background:linear-gradient(135deg,#1a1a2e,#16213e);border-radius:0;border-top:1px solid rgba(255,255,255,.1)}@media(min-width:1024px){.puzzle-controls{border-radius:12px;border:2px solid rgba(255,255,255,.1);padding:20px}}.control-buttons{display:flex;flex-wrap:wrap;gap:12px;justify-content:center}@media(max-width:768px){.control-buttons{gap:8px}}.control-btn{padding:12px 24px;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 8px #0003;flex:1;min-width:100px}@media(max-width:768px){.control-btn{padding:14px 16px;font-size:15px}}.control-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000004d}.control-btn:active{transform:translateY(0)}.hint-btn{background:linear-gradient(135deg,gold,#ffed4e);color:#1a1a2e}.hint-btn:hover{background:linear-gradient(135deg,#ffed4e,gold)}.retry-btn{background:linear-gradient(135deg,#2196f3,#64b5f6);color:#fff}.retry-btn:hover{background:linear-gradient(135deg,#64b5f6,#2196f3)}.skip-btn{background:linear-gradient(135deg,#9e9e9e,#bdbdbd);color:#fff}.skip-btn:hover{background:linear-gradient(135deg,#bdbdbd,#9e9e9e)}.solution-btn{background:linear-gradient(135deg,#673ab7,#9575cd);color:#fff}.solution-btn:hover{background:linear-gradient(135deg,#9575cd,#673ab7)}.next-btn{background:linear-gradient(135deg,#4caf50,#66bb6a);color:#fff}.next-btn:hover{background:linear-gradient(135deg,#66bb6a,#4caf50)}.hint-message,.solution-message{padding:12px 16px;border-radius:8px;text-align:center;font-size:14px;font-weight:500}.hint-message{background:#ffd70033;border:1px solid rgba(255,215,0,.4);color:gold}.solution-message{background:#673ab733;border:1px solid rgba(103,58,183,.4);color:#9575cd}.auto-load-toggle{display:flex;align-items:center;justify-content:center;gap:10px}.toggle-label{font-size:.9rem;color:#ccc;font-weight:500}.switch{position:relative;display:inline-block;width:40px;height:22px}.switch input{opacity:0;width:0;height:0}.slider{position:absolute;cursor:pointer;inset:0;background-color:#444;transition:.4s;border-radius:34px}.slider:before{position:absolute;content:"";height:16px;width:16px;left:3px;bottom:3px;background-color:#fff;transition:.4s;border-radius:50%}input:checked+.slider{background-color:#4caf50}input:checked+.slider:before{transform:translate(18px)}.puzzle-stats{padding:20px;background:linear-gradient(135deg,#1a1a2e,#16213e);border-radius:12px;border:2px solid rgba(255,255,255,.1)}.puzzle-stats h3{margin:0 0 20px;font-size:20px;color:#e0e0e0;text-align:center}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:12px;margin-bottom:16px}.stat-card{display:flex;align-items:center;gap:12px;padding:16px;background:#ffffff0d;border-radius:8px;border:1px solid rgba(255,255,255,.1);transition:all .2s ease}.stat-card:hover{background:#ffffff14;border-color:#fff3;transform:translateY(-2px)}.stat-icon{font-size:28px;line-height:1}.stat-content{flex:1}.stat-value{font-size:24px;font-weight:700;color:#fff;line-height:1;margin-bottom:4px}.stat-label{font-size:12px;color:#9e9e9e;font-weight:500}.streak-card{background:linear-gradient(135deg,#ff57221a,#ff98001a);border-color:#ff98004d}.streak-card .stat-value{color:#ff9800}.success-rate-card{background:linear-gradient(135deg,#4caf501a,#81c7841a);border-color:#4caf504d}.success-rate-card .stat-value{color:#66bb6a}.today-status{margin-top:16px;text-align:center}.status-badge{display:inline-block;padding:10px 20px;border-radius:20px;font-size:14px;font-weight:600}.status-badge.solved{background:#4caf5033;border:1px solid rgba(76,175,80,.4);color:#66bb6a}.status-badge.failed{background:#f4433633;border:1px solid rgba(244,67,54,.4);color:#ef5350}.status-badge.unsolved{background:#ff980033;border:1px solid rgba(255,152,0,.4);color:#ffa726}.current-puzzle-info{margin-top:16px;padding:12px;background:#ffffff0d;border-radius:8px;border:1px solid rgba(255,255,255,.1)}.info-row{display:flex;justify-content:space-between;align-items:center;padding:6px 0}.info-row:not(:last-child){border-bottom:1px solid rgba(255,255,255,.1)}.info-label{font-size:14px;color:#9e9e9e;font-weight:500}.info-value{font-size:16px;color:#e0e0e0;font-weight:600}@media(max-width:768px){.puzzle-stats{border-radius:0;border-left:none;border-right:none;padding:16px}.stats-grid{grid-template-columns:repeat(2,1fr)}.stat-value{font-size:20px}.stat-icon{font-size:24px}.stat-card{padding:12px}}.puzzle-mode{min-height:100vh;display:flex;flex-direction:column}@media(min-width:1024px){.puzzle-mode{padding:20px}.puzzle-content{display:flex;gap:24px;align-items:flex-start}.puzzle-left{flex:0 0 auto;width:560px;display:flex;flex-direction:column;gap:8px}.puzzle-right{flex:1;display:flex;flex-direction:column;gap:20px}}@media(max-width:1023px){.puzzle-mode{padding:0}.puzzle-content{display:flex;flex-direction:column;flex:1}.puzzle-left{width:100%;display:flex;flex-direction:column}.puzzle-right,.puzzle-controls-desktop{display:none}}.puzzle-mobile-header{padding:16px;text-align:center;background:linear-gradient(135deg,#2d2a41cc,#1e1c2ee6)}.puzzle-mobile-header h1{margin:0;font-size:1.5rem;font-weight:700;color:#8b7eea}.puzzle-mobile-header .puzzle-subtitle{margin:4px 0 0;font-size:.9rem;color:#a0a0a0}.puzzle-header-container{display:flex;flex-direction:column;gap:16px;background:linear-gradient(135deg,#1a1a2e,#16213e);border-radius:12px;padding:20px;box-shadow:0 4px 12px #0000004d}@media(max-width:1023px){.puzzle-header-container{border-radius:0;padding:16px}}.puzzle-header-section{text-align:center}.puzzle-header-section h1{margin:0 0 8px;font-size:32px;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.puzzle-subtitle{font-size:16px;color:#9e9e9e;margin:0}.puzzle-tabs{display:flex;justify-content:center;gap:12px}@media(max-width:768px){.puzzle-tabs{gap:8px}}.puzzle-tabs .tab-btn{padding:12px 24px;border:2px solid rgba(255,255,255,.1);background:#ffffff0d;border-radius:8px;font-size:16px;color:#9e9e9e;cursor:pointer;transition:all .2s ease}@media(max-width:768px){.puzzle-tabs .tab-btn{padding:10px 16px;font-size:14px;flex:1}}.tab-btn:hover{border-color:#ffffff4d;background:#ffffff1a;color:#e0e0e0}.tab-btn.active{background:linear-gradient(135deg,#667eea,#764ba2);border-color:#667eea;color:#fff;box-shadow:0 4px 12px #667eea4d}.difficulty-selector{display:flex;align-items:center;justify-content:center;gap:12px}.difficulty-selector label{font-size:16px;font-weight:600;color:#a8dadc}.difficulty-dropdown{padding:10px 16px;background:#ffffff0d;border:2px solid rgba(255,255,255,.1);border-radius:8px;color:#e0e0e0;font-size:15px;cursor:pointer;transition:all .2s ease}@media(max-width:768px){.difficulty-selector{flex-direction:column;gap:8px}.difficulty-dropdown{width:100%}}.difficulty-dropdown:hover{border-color:#ffffff4d;background:#ffffff1a}.difficulty-dropdown:focus{outline:none;border-color:#667eea;box-shadow:0 0 8px #667eea4d}.loading-container,.error-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:16px}.loading-spinner{width:48px;height:48px;border:4px solid rgba(255,255,255,.1);border-top-color:#667eea;border-radius:50%;animation:spin 1s linear infinite}.error-message{font-size:18px;color:#ff6b6b;font-weight:600}.puzzle-bottom-toolbar{display:none}@media(max-width:1023px){.puzzle-bottom-toolbar{display:flex;justify-content:space-around;align-items:stretch;background:#1a1816;border-top:1px solid rgba(255,255,255,.1);padding:8px 4px;position:fixed;bottom:0;left:0;right:0;z-index:50}}.puzzle-bottom-toolbar .toolbar-btn{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;padding:10px 8px;background:transparent;border:none;border-radius:8px;color:#a0a0a0;cursor:pointer;transition:all .2s}.puzzle-bottom-toolbar .toolbar-btn:hover,.puzzle-bottom-toolbar .toolbar-btn.active{background:#ffffff14;color:#fff}.puzzle-bottom-toolbar .toolbar-btn.active{color:#667eea}.puzzle-bottom-toolbar .toolbar-icon{font-size:1.3rem}.puzzle-bottom-toolbar .toolbar-label{font-size:.65rem;text-transform:uppercase;letter-spacing:.5px}.puzzle-popup-overlay{position:fixed;inset:0;z-index:100}.puzzle-popup-overlay:before{content:"";position:absolute;inset:0;background:#0009}.puzzle-popup{position:absolute;bottom:0;left:0;right:0;background:#262421f2;border-radius:16px 16px 0 0;max-height:80vh;overflow:hidden;display:flex;flex-direction:column;animation:slideUp .3s ease-out}.puzzle-popup .popup-header{display:flex;justify-content:space-between;align-items:center;padding:16px}.puzzle-popup .popup-header h2{margin:0;font-size:1.1rem;font-weight:600;color:#fff}.puzzle-popup .popup-close{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:8px;color:#9ca3af;cursor:pointer;font-size:1rem;transition:all .2s}.puzzle-popup .popup-close:hover{background:#ffffff1a;color:#fff}.puzzle-popup .popup-content{padding:16px;overflow-y:auto}.settings-section{margin-bottom:20px}.settings-section:last-child{margin-bottom:0}.settings-label{display:block;margin-bottom:8px;color:#888;font-size:.85rem;text-transform:uppercase;letter-spacing:.5px}.settings-select{width:100%;padding:12px;background:#3a3632;border:1px solid rgba(255,255,255,.1);border-radius:8px;color:#fff;font-size:1rem;cursor:pointer}.settings-select:focus{outline:none;border-color:#667eea}.settings-toggle{display:flex;align-items:center;gap:12px;cursor:pointer;color:#d0d0d0}.settings-toggle input[type=checkbox]{width:18px;height:18px;accent-color:#667eea;cursor:pointer}.settings-toggle span{-webkit-user-select:none;-moz-user-select:none;user-select:none}.settings-btn{width:100%;padding:12px 16px;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s}.settings-btn.skip-btn{background:#ff980026;color:#ffb74d;border:1px solid rgba(255,152,0,.3)}.settings-btn.skip-btn:hover{background:#ff980040}.opening-card{background:linear-gradient(135deg,#2a2a2a,#1e1e1e);border:2px solid #444;border-radius:12px;padding:20px;transition:all .3s ease;cursor:pointer;position:relative;overflow:hidden}.opening-card:hover{transform:translateY(-5px);border-color:#4caf50;box-shadow:0 8px 24px #4caf5033}.card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:15px}.opening-info h3{font-size:1.3rem;margin:0 0 8px;color:#e0e0e0}.eco-code{display:inline-block;padding:4px 8px;background:#444;border-radius:4px;font-size:.8rem;color:#4caf50;font-family:monospace;margin-right:8px}.color-badge{display:inline-block;padding:4px 10px;border-radius:12px;font-size:.8rem;font-weight:600}.color-badge.white{background:#fff3;color:#fff}.color-badge.black{background:#0006;color:#ccc;border:1px solid #666}.confidence-badge{padding:6px 12px;border-radius:16px;font-size:.75rem;font-weight:600;color:#fff;white-space:nowrap}.opening-description{color:#aaa;font-size:.95rem;line-height:1.5;margin-bottom:15px}.opening-stats{display:flex;gap:20px;margin-bottom:15px;padding:12px;background:#0003;border-radius:8px}.stat{flex:1}.stat-label{display:block;font-size:.8rem;color:#888;margin-bottom:5px}.stat-value{font-size:1.2rem;font-weight:600;color:#4caf50}.popularity-bar{height:8px;background:#333;border-radius:4px;overflow:hidden}.popularity-fill{height:100%;background:linear-gradient(90deg,#4caf50,#8bc34a);transition:width .3s ease}.key-ideas{margin-bottom:15px;font-size:.9rem}.key-ideas strong{color:#e0e0e0;display:block;margin-bottom:8px}.key-ideas li{margin-bottom:4px}.card-actions{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.action-btn{padding:10px;border:none;border-radius:8px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s}.learn-btn{background:linear-gradient(135deg,#2196f3,#1976d2);color:#fff}.learn-btn:hover{background:linear-gradient(135deg,#1976d2,#1565c0);transform:scale(1.05)}.practice-btn{background:linear-gradient(135deg,#4caf50,#388e3c);color:#fff}.practice-btn:hover{background:linear-gradient(135deg,#388e3c,#2e7d32);transform:scale(1.05);color:#fff}.explore-btn{background:linear-gradient(135deg,#ff9800,#f57c00);color:#fff}.explore-btn:hover{background:linear-gradient(135deg,#f57c00,#e65100);transform:scale(1.05)}@media(max-width:768px){.opening-card{padding:15px}.card-actions{grid-template-columns:1fr}.opening-stats{flex-direction:column;gap:10px}}.opening-library{max-width:1400px;margin:0 auto;padding:20px}.library-header{text-align:center;margin-bottom:30px}.library-header h1{font-size:2.5rem;margin-bottom:10px;color:#e0e0e0}.library-header p{color:#888;font-size:1.1rem}.library-controls{margin-bottom:30px}.search-and-import{display:grid;grid-template-columns:1fr;gap:12px;margin-bottom:15px}.search-input{width:100%;padding:12px 20px;font-size:1rem;border:2px solid #444;border-radius:8px;background:#2a2a2a;color:#e0e0e0}.search-input:focus{outline:none;border-color:#4caf50}.category-filters{display:flex;gap:10px;flex-wrap:wrap;justify-content:center}.category-btn{padding:10px 20px;border:2px solid #444;border-radius:20px;background:#2a2a2a;color:#e0e0e0;cursor:pointer;transition:all .2s;font-size:.9rem}.category-btn:hover{border-color:#4caf50;background:#333}.category-btn.active{background:#4caf50;border-color:#4caf50;color:#fff}.openings-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:20px;margin-bottom:30px}.no-results{grid-column:1 / -1;text-align:center;padding:40px;color:#888}.no-results .hint{font-size:.9rem;margin-top:10px}.library-stats{text-align:center;padding:20px;color:#888;border-top:1px solid #444}.custom-count{color:#4a9eff;font-weight:600}@media(max-width:768px){.openings-grid{grid-template-columns:1fr}.category-filters{flex-direction:column}.category-btn{width:100%}}.search-input{flex:1!important;width:auto!important}.import-btn{padding:12px 24px;border:2px solid #4a9eff;border-radius:8px;background:#4a9eff;color:#fff;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s;white-space:nowrap}.import-btn:hover{background:#3d8fe8;transform:translateY(-2px);box-shadow:0 4px 12px #4a9eff4d}.opening-trainer{max-width:1600px;margin:0 auto;min-height:100vh}.mobile-title-header{display:flex;flex-direction:row;align-items:center;gap:10px;padding:8px 10px}.mobile-back-btn{padding:6px 10px;background:#444;border:none;border-radius:6px;color:#e0e0e0;cursor:pointer;font-size:1rem;transition:background .2s;flex-shrink:0}.mobile-back-btn:hover{background:#555}@media(min-width:768px){.mobile-title-header{display:none}}.trainer-header{display:none}@media(min-width:768px){.trainer-header{display:flex;flex-direction:row;justify-content:space-between;align-items:center;padding:10px 20px;border-bottom:2px solid #444}}.opening-title{display:flex;flex-wrap:wrap;align-items:center;gap:8px}.opening-title h2{font-size:1.25rem;color:#e0e0e0;margin:0;word-break:break-word}@media(min-width:768px){.opening-title h2{font-size:1.75rem}}.eco-badge{padding:4px 10px;background:#4caf50;color:#fff;border-radius:6px;font-size:.8rem;font-family:monospace;font-weight:600}.back-to-library{padding:8px 16px;background:#444;border:none;border-radius:8px;color:#e0e0e0;cursor:pointer;transition:all .2s;font-size:.9rem;width:100%}@media(min-width:768px){.back-to-library{width:auto}}.back-to-library:hover{background:#555}.trainer-content{display:flex;flex-direction:column;gap:16px}@media(min-width:1024px){.trainer-content{display:grid;grid-template-columns:minmax(400px,600px) 400px;gap:30px;padding:0 20px;align-items:start}}.board-section{display:flex;flex-direction:column;gap:0;width:100%}@media(min-width:1024px){.board-section{gap:0;max-width:600px}}.move-info{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;background:#2a2a2a;border-radius:0}@media(max-width:768px){.move-info{background:none}}@media(min-width:1024px){.move-info{padding:10px 20px;border-radius:8px}}.turn-indicator{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.turn-badge{padding:6px 12px;border-radius:16px;font-weight:600;font-size:.85rem}.turn-badge.w{background:#fff3;color:#fff}.turn-badge.b{background:#0006;color:#ccc;border:1px solid #666}.your-turn-badge{padding:4px 10px;background:#ff9800;color:#fff;border-radius:12px;font-size:.75rem;font-weight:600;animation:pulse 1.5s infinite}.move-counter{color:#888;font-size:.8rem}.feedback-inline{align-items:center;gap:6px;padding:4px 12px;border-radius:12px;font-size:.8rem;font-weight:600;margin-left:auto}.feedback-inline.correct{background:#4caf5033;color:#4caf50}.feedback-inline.incorrect{background:#f4433633;color:#f44336}.feedback-inline .feedback-icon{font-size:.9rem}.board-controls{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;padding:12px;background:#2a2a2a;border-radius:0}@media(min-width:768px){.board-controls{grid-template-columns:repeat(4,1fr);gap:10px;padding:16px;border-radius:8px}}.control-btn{padding:10px 8px;border:2px solid #444;border-radius:8px;background:#333;color:#e0e0e0;cursor:pointer;transition:all .2s;font-size:.8rem;font-weight:600}@media(min-width:768px){.control-btn{padding:12px;font-size:.9rem}}.control-btn:hover:not(:disabled){background:#444;border-color:#4caf50}.control-btn.primary{background:linear-gradient(135deg,#4caf50,#388e3c);border-color:#4caf50;color:#fff}.control-btn.primary:hover:not(:disabled){background:linear-gradient(135deg,#388e3c,#2e7d32)}.control-btn:disabled{opacity:.3;cursor:not-allowed}.info-section{display:none;flex-direction:column;gap:16px;padding:12px;overflow-anchor:none}@media(max-width:767px){.board-controls{display:none}}@media(min-width:768px){.info-section{display:flex}}@media(min-width:1024px){.info-section{gap:20px;padding:0;max-height:calc(100vh - 150px);overflow-y:auto}}.current-move,.opening-description,.key-ideas,.move-list,.variations-list{padding:16px;background:#2a2a2a;border-radius:8px}.current-move h3,.opening-description h3,.key-ideas h3,.move-list h3,.variations-list h3{color:#e0e0e0;margin:0 0 12px;font-size:1rem}.move-text{font-size:1.25rem;font-weight:600;color:#4caf50;font-family:monospace;margin:0}.current-move-mobile{padding:0 1rem}.current-move-mobile .move-text{font-size:1.15rem}.current-move-mobile span.move-text-mobile{font-size:1rem}.show-move-toggle{display:flex;align-items:center;gap:8px;margin-top:12px;cursor:pointer;color:#888;font-size:.85rem}.show-move-toggle input[type=checkbox]{width:16px;height:16px;accent-color:#4CAF50;cursor:pointer}.show-move-toggle span{-webkit-user-select:none;-moz-user-select:none;user-select:none}.learning-note{padding:12px;border-radius:8px;margin-bottom:12px;border-left:4px solid}.learning-note.idea{background:#2196f31a;border-color:#2196f3}.learning-note.trap{background:#ff98001a;border-color:#ff9800}.learning-note.warning{background:#f443361a;border-color:#f44336}.learning-note.tip{background:#4caf501a;border-color:#4caf50}.note-header{display:flex;align-items:center;gap:8px;margin-bottom:8px;color:#e0e0e0}.note-icon{font-size:1.1rem}.learning-note p{color:#aaa;margin:0;line-height:1.5;font-size:.9rem}.opening-description p{color:#aaa;line-height:1.5;margin:0;font-size:.9rem}.key-ideas ul{margin:0;padding-left:20px;color:#aaa}.key-ideas li{margin-bottom:6px;line-height:1.5;font-size:.9rem}.moves-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:4px}.move-item{padding:6px 10px;background:#333;border-radius:4px;display:flex;gap:6px;align-items:center;transition:all .2s}.move-item.current{background:#4caf50;color:#fff;font-weight:600}.move-item.played{opacity:.6}.move-number{color:#888;font-size:.8rem}.move-notation{color:#e0e0e0;font-family:monospace;font-size:.85rem}.move-item.current .move-number,.move-item.current .move-notation{color:#fff}.variation-item{padding:12px;background:#333;border-radius:6px;margin-bottom:8px}.variation-item strong{color:#e0e0e0;display:block;margin-bottom:4px;font-size:.9rem}.main-line-badge{display:inline-block;padding:2px 6px;background:#4caf50;color:#fff;border-radius:4px;font-size:.65rem;margin-left:6px}.variation-item p{color:#aaa;margin:6px 0 0;font-size:.85rem}.completion-message{padding:24px;background:linear-gradient(135deg,#4caf50,#388e3c);border-radius:8px;text-align:center}.completion-message h3{color:#fff;margin:0 0 10px;font-size:1.3rem}.completion-message p{color:#ffffffe6;margin:0 0 16px;font-size:.9rem}.practice-btn{padding:10px 20px;background:#fff;border:none;border-radius:8px;color:#388e3c;font-weight:600;cursor:pointer;transition:all .2s}.practice-btn:hover{transform:scale(1.05);box-shadow:0 4px 12px #0000004d}.mode-badge{padding:4px 10px;border-radius:6px;font-size:.8rem;font-weight:600}.mode-badge.learn{background:#2196f3;color:#fff}.mode-badge.practice{background:#ff9800;color:#fff}.mode-badge.explore{background:#9c27b0;color:#fff}.feedback-banner{padding:12px;border-radius:8px;display:flex;align-items:center;gap:10px;font-weight:600;animation:slideDown .3s ease-out;margin:0 12px}@media(min-width:1024px){.feedback-banner{display:none}}@media(max-width:768px){.feedback-banner{padding:5px;margin-bottom:5px}}.feedback-banner.correct{background:#4caf5033;border:2px solid #4caf50;color:#4caf50}.feedback-banner.incorrect{background:#f4433633;border:2px solid #f44336;color:#f44336}.feedback-icon{font-size:1.3rem}.practice-progress{padding:16px;background:#2a2a2a;border-radius:8px;color:#fff}.practice-progress h3{margin:0 0 12px;color:#fff;font-size:1rem}.progress-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.stat-item{display:flex;flex-direction:column;gap:4px}.stat-label{font-size:.7rem;opacity:.9}.stat-value{font-size:1.1rem;font-weight:700}.practice-instruction{color:#ff9800;font-size:.9rem;font-weight:600;margin-top:8px;animation:pulse 1.5s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.opening-bottom-toolbar{display:flex;justify-content:space-around;align-items:stretch;background:#1a1816;border-top:1px solid rgba(255,255,255,.1);padding:8px 4px;position:fixed;bottom:0;left:0;right:0;z-index:50}@media(min-width:768px){.opening-bottom-toolbar{display:none}}.toolbar-btn{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;padding:10px 8px;background:transparent;border:none;border-radius:8px;color:#a0a0a0;cursor:pointer;transition:all .2s}.toolbar-btn:hover:not(:disabled){background:#ffffff14;color:#fff}.toolbar-btn:disabled{opacity:.4;cursor:not-allowed}.toolbar-icon{font-size:1.3rem}.toolbar-label{font-size:.65rem;text-transform:uppercase;letter-spacing:.5px}.opening-popup-overlay{position:fixed;inset:0;z-index:100}.opening-popup-overlay:before{content:"";position:absolute;inset:0;background:#0009}.opening-popup{position:absolute;bottom:0;left:0;right:0;background:#262421f2;border-radius:16px 16px 0 0;max-height:80vh;overflow:hidden;display:flex;flex-direction:column;animation:slideUp .3s ease-out}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.popup-header{display:flex;justify-content:space-between;align-items:center;padding:16px}.popup-header h2{margin:0;font-size:1.1rem;font-weight:600;color:#fff}.popup-close{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:8px;color:#9ca3af;cursor:pointer;font-size:1rem;transition:all .2s}.popup-close:hover{background:#ffffff1a;color:#fff}.popup-content{padding:20px;overflow-y:auto}.popup-section{margin-bottom:20px}.popup-section:last-child{margin-bottom:0}.popup-section h3{margin:0 0 10px;font-size:.9rem;color:#888;text-transform:uppercase;letter-spacing:1px}.popup-section p{margin:0;color:#d0d0d0;line-height:1.5}.key-ideas-list{margin:0;padding-left:20px;color:#d0d0d0}.key-ideas-list li{margin-bottom:8px;line-height:1.4}.key-ideas-list li:last-child{margin-bottom:0}.popup-moves-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:6px}.popup-move-item{display:flex;align-items:center;gap:4px;padding:8px 10px;background:#3a3632;border-radius:6px;font-family:Roboto Mono,monospace;font-size:.85rem;color:#a0a0a0}.popup-move-item.played{background:#4a4642;color:#d0d0d0}.popup-move-item.current{background:#4caf50;color:#fff}.move-num{color:#888;font-size:.75rem}.move-san{font-weight:500}.progress-stats{display:flex;justify-content:space-around;gap:16px;margin-bottom:20px}.progress-stat{display:flex;flex-direction:column;align-items:center;gap:4px}.stat-value{font-size:1.5rem;font-weight:700;color:#fff}.stat-label{font-size:.7rem;color:#888;text-transform:uppercase;letter-spacing:.5px}.progress-bar-container{height:8px;background:#3a3632;border-radius:4px;overflow:hidden}.progress-bar-fill{height:100%;background:linear-gradient(90deg,#4caf50,#8bc34a);border-radius:4px;transition:width .3s ease}.progress-complete{text-align:center;margin-top:16px;padding:12px;background:#4caf5033;border-radius:8px;color:#4caf50;font-weight:600}.opening-mode{min-height:100vh;padding-bottom:40px}.opening-trainer-placeholder{max-width:800px;margin:0 auto;padding:100px 20px;text-align:center}.opening-trainer-placeholder h2{font-size:2rem;color:#e0e0e0;margin-bottom:20px}.opening-trainer-placeholder p{color:#888;font-size:1.2rem;margin-bottom:30px}.back-btn{padding:12px 24px;background:#4caf50;border:none;border-radius:8px;color:#fff;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s}.back-btn:hover{background:#388e3c;transform:translateY(-2px)}.analyze-mode{padding:10px;min-height:100vh}.analyze-container{display:flex;flex-direction:column;gap:16px}.analyze-left{width:100%;display:flex;flex-direction:column;gap:8px}.analyze-board-container{display:flex;align-items:stretch;gap:4px;width:100%;aspect-ratio:1.08 / 1;max-height:80vh}.analyze-board{flex:1;max-width:100%;aspect-ratio:1 / 1}.analyze-right{width:100%;display:flex;flex-direction:column;gap:12px}.analyze-right h2{margin:0 0 8px;font-size:22px;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.analyze-right h3{margin:0 0 8px;font-size:16px;color:#a8dadc}.pgn-input-section{background:linear-gradient(135deg,#1a1a2e,#16213e);border-radius:12px;padding:12px;box-shadow:0 4px 12px #0000004d}.pgn-input{width:100%;padding:10px;background:#ffffff0d;border:2px solid rgba(255,255,255,.1);border-radius:8px;color:#e0e0e0;font-family:Courier New,monospace;font-size:12px;resize:vertical;margin-bottom:10px;min-height:80px}.pgn-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 8px #667eea4d}.load-btn{width:100%;padding:10px 20px;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;color:#fff;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease}.load-btn:hover{transform:translateY(-2px);box-shadow:0 6px 16px #667eea66}.analysis-controls{background:linear-gradient(135deg,#1a1a2e,#16213e);border-radius:12px;padding:12px;box-shadow:0 4px 12px #0000004d}.analyze-btn{width:100%;padding:12px 20px;background:linear-gradient(135deg,#f093fb,#f5576c);border:none;border-radius:8px;color:#fff;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease}.analyze-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 16px #f5576c66}.analyze-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.move-navigation{background:linear-gradient(135deg,#1a1a2e,#16213e);border-radius:12px;padding:12px;box-shadow:0 4px 12px #0000004d}.nav-info{text-align:center;font-size:14px;color:#a8dadc;margin-bottom:10px;font-weight:600}.nav-buttons{display:grid;grid-template-columns:1fr 1fr;gap:8px}.nav-buttons button{padding:10px 12px;background:#ffffff1a;border:2px solid rgba(255,255,255,.2);border-radius:8px;color:#e0e0e0;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s ease}.nav-buttons button:hover:not(:disabled){background:#fff3;border-color:#fff6}.nav-buttons button:disabled{opacity:.3;cursor:not-allowed}@media(min-width:768px){.analyze-mode{padding:16px}.analyze-container{gap:20px}.analyze-board-container{gap:8px}.pgn-input-section,.analysis-controls,.move-navigation{padding:16px}.pgn-input{font-size:14px;min-height:100px}.load-btn,.analyze-btn{padding:12px 24px;font-size:16px}.nav-buttons{grid-template-columns:repeat(4,1fr)}}@media(min-width:1024px){.analyze-mode{padding:20px}.analyze-container{flex-direction:row;align-items:flex-start;gap:24px}.analyze-left{flex:0 0 auto;width:100%;max-width:560px}.analyze-right{flex:1;min-width:300px}.analyze-right h2{font-size:28px}.analyze-right h3{font-size:18px}.nav-info{font-size:16px}}.game-lobby{max-width:800px;margin:0 auto;padding:2rem}.lobby-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.lobby-header h1{margin:0;color:#fff;font-size:2rem}.user-info{display:flex;flex-direction:column;align-items:flex-end;gap:.5rem}.username{color:#4caf50;font-weight:600;font-size:1.25rem}.ratings{display:flex;gap:1rem;color:#aaa;font-size:.875rem}.time-controls{display:flex;flex-direction:column;gap:2rem}.time-category h3{color:#888;margin:0 0 1rem;font-size:.875rem;text-transform:uppercase;letter-spacing:1px}.time-buttons{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:1rem}.time-button{padding:1.5rem 1rem;background:linear-gradient(145deg,#1a1a2e,#16213e);border:1px solid rgba(255,255,255,.1);border-radius:12px;color:#fff;font-size:1.5rem;font-weight:600;cursor:pointer;transition:all .2s}.time-button:hover{transform:translateY(-4px);border-color:#4caf50;box-shadow:0 8px 24px #4caf504d}.queue-status{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem;background:linear-gradient(145deg,#1a1a2e,#16213e);border-radius:16px;border:1px solid rgba(255,255,255,.1)}.queue-animation{margin-bottom:2rem}.spinner{width:60px;height:60px;border:4px solid rgba(76,175,80,.2);border-top-color:#4caf50;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.queue-status h2{margin:0 0 .5rem;color:#fff}.queue-status p{margin:0 0 2rem;color:#888}.cancel-button{padding:.75rem 2rem;background:#ef535033;border:1px solid rgba(239,83,80,.4);border-radius:8px;color:#ef5350;font-size:1rem;cursor:pointer;transition:all .2s}.cancel-button:hover{background:#ef53504d}.login-prompt{text-align:center;margin-top:3rem;padding:2rem;background:#ffffff05;border-radius:12px;border:1px dashed rgba(255,255,255,.1)}.login-prompt p{color:#888;margin:0 0 1rem}.login-button{padding:.75rem 2rem;background:linear-gradient(135deg,#4caf50,#45a049);border:none;border-radius:8px;color:#fff;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s}.login-button:hover{transform:translateY(-2px);box-shadow:0 4px 16px #4caf5066}.admin-panel{max-width:1200px;margin:0 auto;padding:1.5rem}.admin-loading,.admin-denied{text-align:center;padding:4rem;color:#fff}.admin-denied h2{font-size:2rem;margin-bottom:1rem}.admin-denied button{margin-top:1rem;padding:.75rem 2rem;background:#4caf50;border:none;border-radius:8px;color:#fff;font-weight:600;cursor:pointer}.admin-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;flex-wrap:wrap;gap:1rem}.admin-header h1{color:#fff;margin:0}.admin-tabs{display:flex;gap:.5rem}.admin-tabs button{padding:.5rem 1rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:6px;color:#aaa;cursor:pointer;transition:all .2s}.admin-tabs button.active{background:#4caf50;border-color:#4caf50;color:#fff}.dashboard-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem}.stat-card{background:linear-gradient(145deg,#1a1a2e,#16213e);border-radius:12px;padding:1.5rem;text-align:center;border:1px solid rgba(255,255,255,.1)}.stat-card .stat-value{display:block;font-size:2.5rem;font-weight:700;color:#4caf50}.stat-card .stat-label{display:block;color:#888;margin-top:.5rem}.users-section{background:linear-gradient(145deg,#1a1a2e,#16213e);border-radius:12px;padding:1.5rem;border:1px solid rgba(255,255,255,.1)}.users-search{display:flex;gap:.5rem;margin-bottom:1rem}.users-search input{flex:1;padding:.75rem 1rem;background:#0000004d;border:1px solid rgba(255,255,255,.1);border-radius:6px;color:#fff;font-size:1rem}.users-search button{padding:.75rem 1.5rem;background:#4caf50;border:none;border-radius:6px;color:#fff;font-weight:600;cursor:pointer}.users-search button:disabled{opacity:.7;cursor:wait}.users-loading,.users-empty{text-align:center;padding:3rem;color:#888}.users-loading .loading-spinner{margin:0 auto 1rem}.users-table{overflow-x:auto}.users-table table{width:100%;border-collapse:collapse}.users-table th,.users-table td{padding:.75rem;text-align:left;border-bottom:1px solid rgba(255,255,255,.05)}.users-table th{color:#888;font-weight:600;font-size:.75rem;text-transform:uppercase;letter-spacing:1px}.users-table td{color:#fff;font-size:.875rem}.rating-mini{display:inline-block;padding:.125rem .375rem;background:#0003;border-radius:4px;font-size:.75rem;margin-right:.25rem}.actions{display:flex;gap:.5rem}.edit-btn,.delete-btn{padding:.25rem .5rem;border:none;border-radius:4px;cursor:pointer;font-size:.875rem}.edit-btn{background:#2196f333}.delete-btn{background:#ef535033}.pagination{display:flex;justify-content:center;align-items:center;gap:1rem;margin-top:1rem;color:#888}.pagination button{padding:.5rem 1rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:6px;color:#aaa;cursor:pointer}.pagination button:disabled{opacity:.5;cursor:not-allowed}.modal-overlay{position:fixed;inset:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:1000}.edit-modal{background:linear-gradient(145deg,#1a1a2e,#16213e);border-radius:16px;padding:2rem;min-width:400px;max-width:90vw;border:1px solid rgba(255,255,255,.1)}.edit-modal h3{color:#fff;margin:0 0 1.5rem}.form-group{margin-bottom:1rem}.form-group label{display:block;color:#888;font-size:.875rem;margin-bottom:.25rem}.form-group input{width:100%;padding:.75rem;background:#0000004d;border:1px solid rgba(255,255,255,.1);border-radius:6px;color:#fff}.form-group.checkbox{display:flex;align-items:center;gap:.5rem}.form-group.checkbox input{width:auto}.form-row{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}.modal-buttons{display:flex;gap:1rem;margin-top:1.5rem}.save-btn{flex:1;padding:.75rem;background:#4caf50;border:none;border-radius:6px;color:#fff;font-weight:600;cursor:pointer}.cancel-btn{flex:1;padding:.75rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:6px;color:#aaa;cursor:pointer}@media(max-width:768px){.admin-header{flex-direction:column;align-items:flex-start}.form-row{grid-template-columns:1fr}.edit-modal{min-width:unset;width:95%}}.persona-chat{background:linear-gradient(135deg,#1e1e28f2,#14141ef2);border-radius:12px;padding:16px;border:1px solid rgba(255,255,255,.1);display:flex;flex-direction:column;gap:12px;max-height:300px}.persona-header{display:flex;align-items:center;gap:12px;padding-bottom:12px;border-bottom:1px solid rgba(255,255,255,.1)}.mute-toggle{margin-left:auto;background:#ffffff1a;border:none;border-radius:8px;padding:8px;cursor:pointer;font-size:1.2rem;transition:background .2s,transform .1s}.mute-toggle:hover{background:#fff3;transform:scale(1.05)}.persona-avatar{width:48px;height:48px;border-radius:50%;-o-object-fit:cover;object-fit:cover;border:2px solid rgba(139,92,246,.5)}.persona-info{display:flex;flex-direction:column;gap:2px}.persona-name{font-weight:600;color:#fff;font-size:1rem}.persona-rating{font-size:.75rem;color:#ffffff80}.persona-messages{display:flex;flex-direction:column;gap:8px;overflow-y:auto;flex:1;min-height:60px}.persona-empty{display:flex;align-items:center;justify-content:center;height:100%;color:#fff6;font-style:italic;font-size:.875rem;text-align:center}.persona-message{background:#8b5cf626;border-left:3px solid rgba(139,92,246,.6);padding:10px 14px;border-radius:0 8px 8px 0;animation:slideIn .3s ease-out forwards;opacity:0;transform:translate(-10px)}@keyframes slideIn{to{opacity:1;transform:translate(0)}}.message-text{margin:0;color:#ffffffe6;font-size:.9rem;line-height:1.4;font-style:italic}.persona-chat[data-persona=aunt_judith] .persona-message{background:#ec489926;border-left-color:#ec489999}.persona-chat[data-persona=cousin_kyle] .persona-message{background:#22c55e26;border-left-color:#22c55e99}.persona-chat[data-persona=grandpa_boris] .persona-message{background:#3b82f626;border-left-color:#3b82f699}.persona-messages::-webkit-scrollbar{width:4px}.persona-messages::-webkit-scrollbar-track{background:transparent}.persona-messages::-webkit-scrollbar-thumb{background:#fff3;border-radius:2px}.persona-messages::-webkit-scrollbar-thumb:hover{background:#ffffff4d}
