*,:after,:before{--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:rgba(59,130,246,.5);--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgba(59,130,246,.5);--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }/*! tailwindcss v3.4.18 | MIT License | https://tailwindcss.com*/*,:after,:before{box-sizing:border-box;border:0 solid #e5e7eb}:after,:before{--tw-content:""}:host,html{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:ui-sans-serif,system-ui,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,Noto Color Emoji;font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,pre,samp{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dd,dl,figure,h1,h2,h3,h4,h5,h6,hr,p,pre{margin:0}fieldset{margin:0}fieldset,legend{padding:0}menu,ol,ul{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}[role=button],button{cursor:pointer}:disabled{cursor:default}audio,canvas,embed,iframe,img,object,svg,video{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.container{width:100%}@media (min-width:640px){.container{max-width:640px}}@media (min-width:768px){.container{max-width:768px}}@media (min-width:1024px){.container{max-width:1024px}}@media (min-width:1280px){.container{max-width:1280px}}@media (min-width:1536px){.container{max-width:1536px}}.visible{visibility:visible}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.bottom-4{bottom:1rem}.right-0{right:0}.right-4{right:1rem}.top-0{top:0}.z-50{z-index:50}.order-1{order:1}.order-2{order:2}.mx-auto{margin-left:auto;margin-right:auto}.mb-0{margin-bottom:0}.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.ml-4{margin-left:1rem}.mt-2{margin-top:.5rem}.mt-4{margin-top:1rem}.mt-6{margin-top:1.5rem}.block{display:block}.flex{display:flex}.inline-flex{display:inline-flex}.grid{display:grid}.hidden{display:none}.h-full{height:100%}.max-h-\[50vh\]{max-height:50vh}.min-h-screen{min-height:100vh}.w-full{width:100%}.max-w-3xl{max-width:48rem}.flex-1{flex:1 1 0%}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.list-inside{list-style-position:inside}.list-disc{list-style-type:disc}.grid-cols-5{grid-template-columns:repeat(5,minmax(0,1fr))}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-start{align-items:flex-start}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-8{gap:2rem}.space-y-3>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(.75rem*(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*(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1rem*var(--tw-space-y-reverse))}.overflow-visible{overflow:visible}.overflow-y-auto{overflow-y:auto}.rounded{border-radius:.25rem}.rounded-full{border-radius:9999px}.rounded-lg{border-radius:.5rem}.border{border-width:1px}.border-2{border-width:2px}.border-4{border-width:4px}.border-t{border-top-width:1px}.border-green-200{--tw-border-opacity:1;border-color:rgb(187 247 208/var(--tw-border-opacity,1))}.border-green-300{--tw-border-opacity:1;border-color:rgb(134 239 172/var(--tw-border-opacity,1))}.border-green-600{--tw-border-opacity:1;border-color:rgb(22 163 74/var(--tw-border-opacity,1))}.bg-gray-700{--tw-bg-opacity:1;background-color:rgb(55 65 81/var(--tw-bg-opacity,1))}.bg-green-100{--tw-bg-opacity:1;background-color:rgb(220 252 231/var(--tw-bg-opacity,1))}.bg-green-600{--tw-bg-opacity:1;background-color:rgb(22 163 74/var(--tw-bg-opacity,1))}.bg-red-600{--tw-bg-opacity:1;background-color:rgb(220 38 38/var(--tw-bg-opacity,1))}.bg-red-700{--tw-bg-opacity:1;background-color:rgb(185 28 28/var(--tw-bg-opacity,1))}.bg-red-900\/30{background-color:rgba(127,29,29,.3)}.bg-white\/80{background-color:hsla(0,0%,100%,.8)}.bg-gradient-to-r{background-image:linear-gradient(to right,var(--tw-gradient-stops))}.from-green-50{--tw-gradient-from:#f0fdf4 var(--tw-gradient-from-position);--tw-gradient-to:rgba(240,253,244,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:rgba(220,38,38,0) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-from),var(--tw-gradient-to)}.to-green-600{--tw-gradient-to:#16a34a var(--tw-gradient-to-position)}.to-red-50{--tw-gradient-to:#fef2f2 var(--tw-gradient-to-position)}.p-4{padding:1rem}.p-6{padding:1.5rem}.p-8{padding:2rem}.px-3{padding-left:.75rem;padding-right:.75rem}.px-4{padding-left:1rem;padding-right:1rem}.px-6{padding-left:1.5rem;padding-right:1.5rem}.py-1{padding-top:.25rem;padding-bottom:.25rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.py-3{padding-top:.75rem;padding-bottom:.75rem}.py-8{padding-top:2rem;padding-bottom:2rem}.pt-3{padding-top:.75rem}.text-center{text-align:center}.text-right{text-align:right}.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-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-bold{font-weight:700}.font-medium{font-weight:500}.font-semibold{font-weight:600}.italic{font-style:italic}.leading-relaxed{line-height:1.625}.text-blue-600{--tw-text-opacity:1;color:rgb(37 99 235/var(--tw-text-opacity,1))}.text-gray-600{--tw-text-opacity:1;color:rgb(75 85 99/var(--tw-text-opacity,1))}.text-gray-700{--tw-text-opacity:1;color:rgb(55 65 81/var(--tw-text-opacity,1))}.text-gray-800{--tw-text-opacity:1;color:rgb(31 41 55/var(--tw-text-opacity,1))}.text-green-200{--tw-text-opacity:1;color:rgb(187 247 208/var(--tw-text-opacity,1))}.text-green-600{--tw-text-opacity:1;color:rgb(22 163 74/var(--tw-text-opacity,1))}.text-green-700{--tw-text-opacity:1;color:rgb(21 128 61/var(--tw-text-opacity,1))}.text-green-800{--tw-text-opacity:1;color:rgb(22 101 52/var(--tw-text-opacity,1))}.text-red-600{--tw-text-opacity:1;color:rgb(220 38 38/var(--tw-text-opacity,1))}.text-white{--tw-text-opacity:1;color:rgb(255 255 255/var(--tw-text-opacity,1))}.text-white\/80{color:hsla(0,0%,100%,.8)}.opacity-50{opacity:.5}.shadow-lg{--tw-shadow:0 10px 15px -3px rgba(0,0,0,.1),0 4px 6px -4px rgba(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)}.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-sm{--tw-backdrop-blur:blur(4px);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{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-all{transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-colors{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-opacity{transition-property:opacity;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.duration-300{transition-duration:.3s}.ease-in-out{transition-timing-function:cubic-bezier(.4,0,.2,1)}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Roboto,Segoe UI,Tahoma,Geneva,Verdana,sans-serif;background:linear-gradient(180deg,#0a0e27 0,#1a1f3a 40%,#2d3561 70%,#4a5f8c 85%,#e8f4f8);position:relative;overflow:hidden}body:before{bottom:0;height:40vh;background:radial-gradient(ellipse 800px 300px at 20% 100%,hsla(0,0%,100%,.9) 0,transparent 50%),radial-gradient(ellipse 600px 250px at 60% 100%,rgba(240,248,255,.8) 0,transparent 50%),radial-gradient(ellipse 700px 280px at 85% 100%,hsla(0,0%,100%,.85) 0,transparent 50%)}body:after,body:before{content:"";position:fixed;left:0;right:0;z-index:0;pointer-events:none}body:after{top:0;bottom:50%;background-image:radial-gradient(2px 2px at 20% 30%,#fff,transparent),radial-gradient(2px 2px at 60% 70%,#fff,transparent),radial-gradient(1px 1px at 50% 50%,#fff,transparent),radial-gradient(1px 1px at 80% 10%,#fff,transparent),radial-gradient(2px 2px at 90% 60%,#fff,transparent),radial-gradient(1px 1px at 33% 80%,#fff,transparent),radial-gradient(2px 2px at 15% 15%,#fff,transparent),radial-gradient(1px 1px at 70% 25%,#fff,transparent),radial-gradient(1px 1px at 40% 10%,#fff,transparent),radial-gradient(2px 2px at 25% 60%,#fff,transparent);background-size:200% 200%;background-position:0 0;animation:twinkleStars 5s ease-in-out infinite}@keyframes twinkleStars{0%,to{opacity:.8}50%{opacity:1}}.snowflake{position:fixed;top:-10px;z-index:1;-webkit-user-select:none;-moz-user-select:none;user-select:none;cursor:default;animation:snowfall linear infinite;color:#fff;font-size:1em;pointer-events:none}@keyframes snowfall{0%{transform:translateY(0) translateX(0) rotate(0deg)}to{transform:translateY(100vh) translateX(100px) rotate(1turn)}}.snowflake:first-of-type{left:1%;animation-duration:8s;animation-delay:0s;font-size:.8em}.snowflake:nth-of-type(2){left:10%;animation-duration:10s;animation-delay:1s;font-size:1em}.snowflake:nth-of-type(3){left:20%;animation-duration:7s;animation-delay:2s;font-size:.6em}.snowflake:nth-of-type(4){left:30%;animation-duration:9s;animation-delay:.5s;font-size:1.2em}.snowflake:nth-of-type(5){left:40%;animation-duration:11s;animation-delay:1.5s;font-size:.9em}.snowflake:nth-of-type(6){left:50%;animation-duration:8.5s;animation-delay:2.5s;font-size:.7em}.snowflake:nth-of-type(7){left:60%;animation-duration:9.5s;animation-delay:.8s;font-size:1.1em}.snowflake:nth-of-type(8){left:70%;animation-duration:10.5s;animation-delay:1.8s;font-size:.8em}.snowflake:nth-of-type(9){left:80%;animation-duration:7.5s;animation-delay:.3s;font-size:1em}.snowflake:nth-of-type(10){left:90%;animation-duration:8.8s;animation-delay:2.3s;font-size:.9em}.snowflake:nth-of-type(11){left:15%;animation-duration:9.2s;animation-delay:1.2s;font-size:.75em}.snowflake:nth-of-type(12){left:25%;animation-duration:10.8s;animation-delay:.7s;font-size:1.15em}.snowflake:nth-of-type(13){left:35%;animation-duration:8.3s;animation-delay:2.8s;font-size:.85em}.snowflake:nth-of-type(14){left:45%;animation-duration:9.8s;animation-delay:1.3s;font-size:.95em}.snowflake:nth-of-type(15){left:55%;animation-duration:7.8s;animation-delay:.4s;font-size:1.05em}.snowflake:nth-of-type(16){left:65%;animation-duration:11.2s;animation-delay:2.2s;font-size:.7em}.snowflake:nth-of-type(17){left:75%;animation-duration:8.7s;animation-delay:1.7s;font-size:1.25em}.snowflake:nth-of-type(18){left:85%;animation-duration:9.3s;animation-delay:.9s;font-size:.65em}.snowflake:nth-of-type(19){left:95%;animation-duration:10.3s;animation-delay:2.7s;font-size:1.1em}.snowflake:nth-of-type(20){left:5%;animation-duration:7.2s;animation-delay:1.4s;font-size:.8em}.container{z-index:10}.container,.door{position:relative}.door{width:100px;height:100px;border-radius:4px;display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;transition:all .3s ease;border:3px solid;font-weight:700;font-size:2rem}@media (max-width:1600px){.door{width:90px;height:90px}.door,.door-number{font-size:1.8rem}}@media (max-width:1400px){.door{width:80px;height:80px;font-size:1.6rem}.door-number{font-size:1.6rem;top:4px;left:4px}#calendar{gap:.5rem}}@media (max-width:1200px){.door{width:70px;height:70px}.door,.door-number{font-size:1.4rem}.door-icon{font-size:1rem}.door-svg-icon-centered{width:24px;height:24px;bottom:4px;right:4px}.door-number{font-size:1.8rem;top:4px;left:4px}.lock-icon{font-size:1.2rem}}.door.locked{background:linear-gradient(135deg,#4a5568,#2d3748);border-color:#1a202c;color:#718096;cursor:not-allowed}.door.locked .door-number{z-index:2}.door.locked .door-svg-icon-centered{z-index:1}.door.unlocked{background:linear-gradient(135deg,#dc2626,#ef4444);border-color:#059669;color:#fff;box-shadow:0 0 15px rgba(16,185,129,.5)}.door.unlocked:hover{transform:scale(1.1);box-shadow:0 0 25px rgba(16,185,129,.8)}.door.completed{background:linear-gradient(135deg,#059669,#10b981);border-color:#f59e0b;color:#fff;box-shadow:0 0 20px rgba(245,158,11,.6)}.door.completed:hover{transform:scale(1.08)}.door-number{font-size:2rem;font-weight:700;position:absolute;top:5px;left:5px;z-index:2}.door-icon{position:absolute;bottom:8px;font-size:1.2rem}.door-svg-icon-centered{position:absolute;bottom:5px;right:5px;width:28px;height:28px;display:flex;align-items:center;justify-content:center;z-index:1}.door-completed-icon{animation:iconFadeIn .5s ease}@keyframes iconFadeIn{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}.lock-icon{font-size:1.5rem;margin-top:4px}.modal{position:fixed;top:0;left:0;right:0;bottom:0;z-index:1000;display:flex;align-items:center;justify-content:flex-start;padding-left:5%}#christmas-modal{justify-content:center;padding-left:0}.modal.hidden{display:none}.modal-backdrop{position:absolute;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.8);backdrop-filter:blur(8px);animation:backdropFadeIn .3s ease}@keyframes backdropFadeIn{0%{opacity:0}to{opacity:1}}.modal-content{position:relative;background:linear-gradient(180deg,#fff 0,#f8fafc);border-radius:12px;max-width:650px;width:90%;max-height:85vh;display:flex;flex-direction:column;box-shadow:0 0 0 1px rgba(16,185,129,.1),0 20px 60px -15px rgba(0,0,0,.4),0 0 100px -20px rgba(16,185,129,.3);border:3px solid transparent;background-clip:padding-box;animation:modalSlideIn .5s cubic-bezier(.34,1.56,.64,1)}.modal-content:before{content:"";position:absolute;top:-3px;left:-3px;right:-3px;bottom:-3px;border-radius:12px;padding:3px;background:linear-gradient(135deg,#10b981,#059669,#f59e0b,#ef4444);-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none;animation:borderRotate 3s linear infinite}@keyframes borderRotate{0%{filter:hue-rotate(0deg)}to{filter:hue-rotate(1turn)}}@keyframes modalSlideIn{0%{transform:translateY(-100px) scale(.9);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}.modal-header{padding:2rem;border-bottom:none;display:flex;justify-content:space-between;align-items:center;background:linear-gradient(135deg,#d1fae5,#a7f3d0 50%,#6ee7b7);border-radius:9px 9px 0 0;position:relative;overflow:hidden}.modal-header:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle,hsla(0,0%,100%,.3) 0,transparent 70%);animation:shimmer 3s ease-in-out infinite}@keyframes shimmer{0%,to{transform:translate(-25%,-25%)}50%{transform:translate(25%,25%)}}.modal-header h2{position:relative;z-index:1;text-shadow:0 2px 4px rgba(0,0,0,.1)}.modal-header button{position:relative;z-index:1;transition:all .3s ease;width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:hsla(0,0%,100%,.2)}.modal-header button:hover{background:hsla(0,0%,100%,.4);transform:rotate(90deg)}.modal-body{padding:2.5rem;position:relative;overflow-y:auto;flex:1}.modal-content.christmas-special{border-color:#dc2626}.modal-content.christmas-special .modal-header{background:linear-gradient(135deg,#dc2626,#ef4444 50%,#059669);color:#fff}.modal-content.christmas-special .modal-header h2{color:#fff}#feedback.correct{color:#059669;font-size:1.2rem;animation:celebrate .6s ease;padding:1rem;background:linear-gradient(135deg,#d1fae5,#a7f3d0);border-radius:8px;border:2px solid #10b981;box-shadow:0 4px 12px rgba(16,185,129,.3)}#feedback.incorrect{color:#dc2626;font-size:1.1rem;padding:1rem;background:linear-gradient(135deg,#fee2e2,#fecaca);border-radius:8px;border:2px solid #ef4444;box-shadow:0 4px 12px rgba(239,68,68,.3);animation:shake .5s ease}@keyframes celebrate{0%,to{transform:scale(1)}25%{transform:scale(1.05) rotate(-2deg)}75%{transform:scale(1.05) rotate(2deg)}}@keyframes shake{0%,to{transform:translateX(0)}25%{transform:translateX(-10px)}75%{transform:translateX(10px)}}.decoration{cursor:pointer;transition:filter .3s ease,opacity .3s ease;animation:decorationAppear .6s ease;transform-origin:center center}.decoration:hover{filter:drop-shadow(0 0 8px rgba(255,215,0,.8)) brightness(1.3);opacity:1}@keyframes decorationAppear{0%{opacity:0;transform:scale(0) translate(0)}60%{transform:scale(1.2) translate(0)}to{opacity:1;transform:scale(1) translate(0)}}.decoration-ball{filter:drop-shadow(0 2px 4px rgba(0,0,0,.3))}.decoration-star{filter:drop-shadow(0 2px 8px rgba(245,158,11,.6))}.decoration-candy{filter:drop-shadow(0 2px 4px rgba(220,38,38,.4))}.decoration-tooltip{position:fixed;background:hsla(0,0%,100%,.95);color:#1a202c;padding:4px 10px;border-radius:6px;box-shadow:0 2px 8px rgba(0,0,0,.2);z-index:2000;font-size:.8rem;transform:translate(-50%,-100%);margin-top:-8px;opacity:0;transition:opacity .2s ease,transform .2s ease;pointer-events:none;white-space:nowrap;font-weight:500;border:1px solid #e2e8f0;border-bottom:2px solid #10b981}.decoration-tooltip:after{content:"";position:absolute;top:100%;left:50%;margin-left:-6px;border:6px solid transparent;border-top-color:#10b981}.decoration-tooltip.visible{opacity:1;transform:translate(-50%,-100%) translateY(-5px)}@keyframes successPulse{0%,to{transform:scale(1);box-shadow:0 0 20px rgba(245,158,11,.6)}50%{transform:scale(1.05);box-shadow:0 0 40px rgba(245,158,11,.9)}}.door.success-animation{animation:successPulse .8s ease 3}.modal-content::-webkit-scrollbar{width:8px}.modal-content::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}.modal-content::-webkit-scrollbar-thumb{background:#10b981;border-radius:4px}.modal-content::-webkit-scrollbar-thumb:hover{background:#059669}@media (max-width:768px){.door{width:50px;height:50px;border:2px solid}.door,.door-number{font-size:1rem}.door-icon{font-size:.8rem}.door-svg-icon-centered{width:16px;height:16px;bottom:3px;right:3px}.door-number{font-size:1.2rem;top:2px;left:2px}.lock-icon{font-size:.9rem}#calendar{gap:.4rem;padding:.75rem}}@media (max-width:380px){.door{width:45px;height:45px;font-size:.9rem}#calendar{gap:.25rem;padding:.5rem}}.decoration-loading{opacity:0}@keyframes twinkle{0%,to{opacity:1}50%{opacity:.5}}.tree-light{animation:twinkle 2s ease-in-out infinite}@keyframes glow{0%,to{box-shadow:0 0 15px rgba(16,185,129,.5)}50%{box-shadow:0 0 25px rgba(16,185,129,.8)}}.door.unlocked{animation:glow 2s ease-in-out infinite}.problem-icon-container{display:flex;justify-content:center;align-items:center;margin-bottom:1.5rem;min-height:60px}.problem-icon-container svg{max-width:60px;max-height:60px;filter:drop-shadow(0 2px 4px rgba(0,0,0,.2))}#hint-display{background:linear-gradient(135deg,#dc2626,#ef4444);padding:1rem;border-radius:6px;border-left:5px solid #b91c1c;font-size:.95rem;box-shadow:0 2px 8px rgba(220,38,38,.3);animation:slideDown .3s ease;color:#fff}#hint-display:before{content:"💡 Hint: ";font-weight:700;color:#fff}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}#modal-question,.problem-formula{font-family:Crimson Text,Times New Roman,Times,serif}.problem-formula{background:linear-gradient(135deg,#f3f4f6,#e5e7eb);padding:1.25rem;border-radius:8px;border-left:5px solid #10b981;margin:1rem 0;font-size:1.1em;box-shadow:0 2px 8px rgba(0,0,0,.1),inset 0 1px 0 hsla(0,0%,100%,.8);position:relative;overflow:hidden}.problem-hint{background:linear-gradient(135deg,#dc2626,#ef4444);padding:1rem;border-radius:6px;border-left:5px solid #b91c1c;margin:.75rem 0;font-size:.95rem;box-shadow:0 2px 8px rgba(220,38,38,.3);position:relative;color:#fff}.problem-hint:before{content:"💡";margin-right:8px}#answer-input{transition:all .3s ease;box-shadow:0 2px 8px rgba(0,0,0,.05)}#answer-input:focus{box-shadow:0 0 0 3px rgba(16,185,129,.1),0 4px 12px rgba(16,185,129,.2);transform:translateY(-1px)}#submit-answer{box-shadow:0 4px 12px rgba(5,150,105,.3);position:relative;overflow:hidden}#submit-answer>*{position:relative;z-index:1}#submit-answer:before{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:hsla(0,0%,100%,.3);transform:translate(-50%,-50%);transition:width .6s,height .6s;z-index:0}#submit-answer:hover:before{width:300px;height:300px}#submit-answer:active{transform:scale(.98)}.locked-tooltip{position:fixed;top:0;left:0;right:0;bottom:0;z-index:2000;display:flex;align-items:center;justify-content:center;animation:fadeIn .3s ease}.locked-tooltip.hidden{display:none}.locked-tooltip:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.75);backdrop-filter:blur(8px)}.locked-tooltip-content{position:relative;background:linear-gradient(135deg,#1f2937,#374151);border-radius:12px;padding:2.5rem;max-width:400px;width:90%;text-align:center;box-shadow:0 0 0 1px rgba(245,158,11,.3),0 20px 60px rgba(0,0,0,.5),0 0 100px rgba(245,158,11,.2);animation:tooltipBounceIn .5s cubic-bezier(.68,-.55,.265,1.55);border:2px solid rgba(245,158,11,.5)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes tooltipBounceIn{0%{transform:scale(.3) translateY(-50px);opacity:0}50%{transform:scale(1.05) translateY(0)}70%{transform:scale(.95)}to{transform:scale(1);opacity:1}}.locked-tooltip-icon{font-size:4rem;margin-bottom:1rem;animation:lockShake 2s ease-in-out infinite;filter:drop-shadow(0 4px 8px rgba(0,0,0,.3))}@keyframes lockShake{0%,to{transform:rotate(0deg)}25%{transform:rotate(-10deg)}75%{transform:rotate(10deg)}}.locked-tooltip-title{font-size:1.75rem;font-weight:700;color:#f59e0b;margin-bottom:1rem;text-shadow:0 2px 4px rgba(0,0,0,.3)}.locked-tooltip-message{font-size:1.1rem;color:#e5e7eb;margin-bottom:.75rem;line-height:1.6}.locked-tooltip-countdown{font-size:1.5rem;font-weight:700;color:#fbbf24;margin-bottom:1.5rem;font-family:Courier New,monospace;text-shadow:0 0 10px rgba(251,191,36,.5)}.locked-tooltip-close{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;border:none;padding:.75rem 2rem;border-radius:8px;font-size:1rem;font-weight:700;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px rgba(245,158,11,.4)}.locked-tooltip-close:hover{transform:translateY(-2px);box-shadow:0 6px 16px rgba(245,158,11,.6);background:linear-gradient(135deg,#fbbf24,#f59e0b)}.locked-tooltip-close:active{transform:translateY(0)}.christmas-stats-modal{max-width:900px}.christmas-statistics{margin:2rem 0;text-align:left}.stats-summary{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:2rem}.stat-card{background:linear-gradient(135deg,#f0fdf4,#dcfce7);border:2px solid #10b981;border-radius:8px;padding:1.5rem;text-align:center;box-shadow:0 4px 12px rgba(16,185,129,.2);transition:transform .3s ease}.stat-card:hover{transform:translateY(-4px);box-shadow:0 6px 16px rgba(16,185,129,.3)}.stat-number{font-size:3rem;font-weight:700;color:#059669;line-height:1;margin-bottom:.5rem}.stat-label{font-size:.875rem;color:#065f46;font-weight:500;text-transform:uppercase;letter-spacing:.05em}.attempts-chart{background:linear-gradient(135deg,#fef3c7,#fde68a);border:2px solid #f59e0b;border-radius:8px;padding:1.5rem;margin-bottom:2rem;box-shadow:0 4px 12px rgba(245,158,11,.2)}.chart-title{font-size:1.25rem;font-weight:700;color:#92400e;margin-bottom:1rem;text-align:center}.chart-container{display:flex;gap:.25rem;align-items:flex-end;height:200px;padding:1rem .5rem;background:hsla(0,0%,100%,.5);border-radius:8px}.chart-bar-wrapper{flex:1;display:flex;flex-direction:column;align-items:center;height:100%}.chart-bar{width:100%;min-height:2px;border-radius:4px 4px 0 0;transition:all .3s ease;cursor:pointer;margin-top:auto}.chart-bar.completed{background:linear-gradient(0deg,#10b981,#34d399)}.chart-bar.incomplete{background:linear-gradient(0deg,#9ca3af,#d1d5db)}.chart-bar:hover{transform:scaleY(1.05);filter:brightness(1.1)}.chart-label{font-size:.7rem;color:#78350f;margin-top:.25rem;font-weight:500}.perfect-scores{background:linear-gradient(135deg,#fef2f2,#fee2e2);border:2px solid #ef4444;border-radius:8px;padding:1.5rem;box-shadow:0 4px 12px rgba(239,68,68,.2)}.perfect-list{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center}.perfect-badge{display:inline-block;background:linear-gradient(135deg,#fbbf24,#f59e0b);color:#fff;padding:.5rem 1rem;border-radius:12px;font-weight:700;font-size:.875rem;box-shadow:0 2px 8px rgba(245,158,11,.4);transition:transform .3s ease}.perfect-badge:hover{transform:scale(1.1)}.no-perfects{color:#991b1b;font-style:italic;text-align:center;margin:0}@media (max-width:768px){.stats-summary{grid-template-columns:1fr}.chart-container{height:150px}.chart-label{font-size:.6rem}.stat-number{font-size:2rem}}.hover\:scale-105:hover{--tw-scale-x:1.05;--tw-scale-y:1.05;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.hover\:bg-gray-600:hover{--tw-bg-opacity:1;background-color:rgb(75 85 99/var(--tw-bg-opacity,1))}.hover\:bg-green-500:hover{--tw-bg-opacity:1;background-color:rgb(34 197 94/var(--tw-bg-opacity,1))}.hover\:bg-green-700:hover{--tw-bg-opacity:1;background-color:rgb(21 128 61/var(--tw-bg-opacity,1))}.hover\:bg-red-600:hover{--tw-bg-opacity:1;background-color:rgb(220 38 38/var(--tw-bg-opacity,1))}.hover\:bg-red-700:hover{--tw-bg-opacity:1;background-color:rgb(185 28 28/var(--tw-bg-opacity,1))}.hover\:bg-white:hover{--tw-bg-opacity:1;background-color:rgb(255 255 255/var(--tw-bg-opacity,1))}.hover\:text-blue-800:hover{--tw-text-opacity:1;color:rgb(30 64 175/var(--tw-text-opacity,1))}.hover\:text-gray-200:hover{--tw-text-opacity:1;color:rgb(229 231 235/var(--tw-text-opacity,1))}.hover\:text-green-800:hover{--tw-text-opacity:1;color:rgb(22 101 52/var(--tw-text-opacity,1))}.hover\:text-red-800:hover{--tw-text-opacity:1;color:rgb(153 27 27/var(--tw-text-opacity,1))}.hover\:opacity-100:hover{opacity:1}.hover\:shadow-xl:hover{--tw-shadow:0 20px 25px -5px rgba(0,0,0,.1),0 8px 10px -6px rgba(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)}.focus\:border-green-500:focus{--tw-border-opacity:1;border-color:rgb(34 197 94/var(--tw-border-opacity,1))}.focus\:outline-none:focus{outline:2px solid transparent;outline-offset:2px}@media (min-width:768px){.md\:text-5xl{font-size:3rem;line-height:1}}@media (min-width:1024px){.lg\:order-none{order:0}.lg\:mt-0{margin-top:0}.lg\:h-screen{height:100vh}.lg\:max-h-\[80vh\]{max-height:80vh}.lg\:w-1\/4{width:25%}.lg\:w-3\/4{width:75%}.lg\:flex-row{flex-direction:row}.lg\:gap-4{gap:1rem}.lg\:overflow-hidden{overflow:hidden}}