@import "https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700;800;900&family=Space+Grotesk:wght@400;500;600;700&display=swap";
@font-face{font-family:Geist;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/8a480f0b521d4e75-s.06d3mdzz5bre_.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Geist;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/7178b3e590c64307-s.11.cyxs5p-0z~.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Geist;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/caa3a2e1cccd8315-s.p.16t1db8_9y2o~.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Geist Fallback;src:local(Arial);ascent-override:95.94%;descent-override:28.16%;line-gap-override:0.0%;size-adjust:104.76%}.geist_a71539c9-module__T19VSG__className{font-family:Geist,Geist Fallback;font-style:normal}.geist_a71539c9-module__T19VSG__variable{--font-geist-sans:"Geist", "Geist Fallback"}
@font-face{font-family:Geist Mono;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/4fa387ec64143e14-s.0q3udbd2bu5yp.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Geist Mono;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/bbc41e54d2fcbd21-s.0gw~uztddq1df.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Geist Mono;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/797e433ab948586e-s.p.0.q-h669a_dqa.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Geist Mono Fallback;src:local(Arial);ascent-override:74.67%;descent-override:21.92%;line-gap-override:0.0%;size-adjust:134.59%}.geist_mono_8d43a2aa-module__8Li5zG__className{font-family:Geist Mono,Geist Mono Fallback;font-style:normal}.geist_mono_8d43a2aa-module__8Li5zG__variable{--font-geist-mono:"Geist Mono", "Geist Mono Fallback"}
:root{--bg-primary:#141428;--bg-secondary:#1c1c3a;--bg-card:#ffffff05;--bg-card-hover:#ffffff0d;--bg-glass:#ffffff08;--border-glass:#ffffff1a;--gradient-primary:linear-gradient(135deg, #7c3aed, #ec4899, #f97316);--gradient-secondary:linear-gradient(135deg, #06b6d4, #8b5cf6, #ec4899);--gradient-hero:linear-gradient(160deg, #141428 0%, #221440 30%, #141e38 60%, #141428 100%);--gradient-btn:linear-gradient(135deg, #8b5cf6 0%, #ec4899 50%, #f97316 100%);--gradient-btn-hover:linear-gradient(135deg, #9d6eff 0%, #f472b6 50%, #fb923c 100%);--text-primary:#f1f5f9;--text-secondary:#f1f5f9a6;--text-muted:#f1f5f966;--text-accent:#c084fc;--shadow-card:0 8px 32px #0000004d;--shadow-glow:0 0 40px #8b5cf626;--shadow-glow-strong:0 0 60px #8b5cf64d;--section-gap:6rem;--container-max:1200px;--radius-sm:8px;--radius-md:14px;--radius-lg:20px;--radius-xl:28px;--ease-out-expo:cubic-bezier(.16, 1, .3, 1);--transition-fast:.2s var(--ease-out-expo);--transition-normal:.35s var(--ease-out-expo);--transition-slow:.6s var(--ease-out-expo)}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased}body{background:radial-gradient(circle at 50% 30%, #2e1e5b 0%, var(--bg-primary) 70%);color:var(--text-primary);background-attachment:fixed;min-height:100vh;font-family:Outfit,sans-serif;line-height:1.6;overflow-x:hidden}img{max-width:100%;display:block}a{color:inherit;text-decoration:none}button{cursor:pointer;border:none;outline:none;font-family:inherit}.bg-orbs{z-index:0;pointer-events:none;width:100%;height:100%;position:fixed;top:0;left:0;overflow:hidden}.bg-orbs .orb{filter:blur(100px);opacity:.3;border-radius:50%;animation:20s ease-in-out infinite orbFloat;position:absolute}.bg-orbs .orb:first-child{background:#7c3aed;width:500px;height:500px;animation-duration:25s;top:-10%;left:-5%}.bg-orbs .orb:nth-child(2){background:#ec4899;width:400px;height:400px;animation-duration:30s;animation-delay:-5s;top:40%;right:-10%}.bg-orbs .orb:nth-child(3){background:#06b6d4;width:350px;height:350px;animation-duration:22s;animation-delay:-10s;bottom:-5%;left:30%}@keyframes orbFloat{0%,to{transform:translate(0)scale(1)}25%{transform:translate(40px,-30px)scale(1.05)}50%{transform:translate(-20px,20px)scale(.95)}75%{transform:translate(30px,40px)scale(1.02)}}.glass-shapes{z-index:0;pointer-events:none;width:100%;height:100%;position:fixed;top:0;left:0;overflow:hidden}.glass-shape{-webkit-backdrop-filter:blur(12px);border-radius:var(--radius-xl);background:#ffffff08;border:1px solid #ffffff0f;position:absolute}.glass-shape.shape-1{width:280px;height:180px;animation:28s ease-in-out infinite glassDrift;top:12%;right:8%;transform:rotate(-8deg)}.glass-shape.shape-2{border-radius:50%;width:200px;height:200px;animation:32s ease-in-out -8s infinite glassDrift;top:55%;left:5%}.glass-shape.shape-3{width:320px;height:120px;animation:25s ease-in-out -14s infinite glassDrift;bottom:18%;right:15%;transform:rotate(5deg)}.glass-shape.shape-4{border-radius:30% 70% 70% 30%/30% 30% 70% 70%;width:150px;height:150px;animation:30s ease-in-out -5s infinite glassDrift;top:35%;left:40%}.glass-shape.shape-5{width:240px;height:100px;animation:35s ease-in-out -18s infinite glassDrift;bottom:40%;left:18%;transform:rotate(-3deg)}@keyframes glassDrift{0%,to{transform:translate(0, 0) rotate(var(--r,0deg));opacity:.6}25%{transform:translate(15px, -20px) rotate(var(--r,0deg));opacity:.8}50%{transform:translate(-10px, 15px) rotate(var(--r,0deg));opacity:.5}75%{transform:translate(20px, 10px) rotate(var(--r,0deg));opacity:.7}}.bg-puzzle-pieces{z-index:0;pointer-events:none;width:100%;height:100%;position:fixed;top:0;left:0;overflow:hidden}.bg-piece{opacity:.06;font-size:1.6rem;animation:20s ease-in-out infinite bgPieceFloat;position:absolute}.bg-piece:first-child{font-size:1.4rem;animation-duration:22s;animation-delay:0s;top:8%;left:12%}.bg-piece:nth-child(2){font-size:2rem;animation-duration:26s;animation-delay:-3s;top:22%;right:18%;transform:rotate(45deg)}.bg-piece:nth-child(3){font-size:1.2rem;animation-duration:30s;animation-delay:-7s;top:45%;left:6%;transform:rotate(-20deg)}.bg-piece:nth-child(4){font-size:1.8rem;animation-duration:24s;animation-delay:-11s;top:60%;right:10%;transform:rotate(15deg)}.bg-piece:nth-child(5){font-size:1.3rem;animation-duration:28s;animation-delay:-4s;top:75%;left:25%;transform:rotate(-35deg)}.bg-piece:nth-child(6){font-size:1.1rem;animation-duration:33s;animation-delay:-9s;top:35%;right:30%;transform:rotate(60deg)}.bg-piece:nth-child(7){font-size:1.6rem;animation-duration:27s;animation-delay:-15s;bottom:12%;left:45%;transform:rotate(-10deg)}.bg-piece:nth-child(8){font-size:1.4rem;animation-duration:31s;animation-delay:-2s;bottom:25%;right:5%;transform:rotate(30deg)}@keyframes bgPieceFloat{0%,to{transform:translateY(0)rotate(0)}25%{transform:translateY(-15px)rotate(8deg)}50%{transform:translateY(8px)rotate(-5deg)}75%{transform:translateY(-10px)rotate(3deg)}}.container{max-width:var(--container-max);z-index:1;margin:0 auto;padding:0 1.5rem;position:relative}.navbar{z-index:100;-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--border-glass);transition:var(--transition-normal);background:#0a0a1ab3;padding:1rem 0;position:fixed;top:0;left:0;right:0}.navbar .container{justify-content:space-between;align-items:center;display:flex}.logo{background:var(--gradient-primary);-webkit-text-fill-color:transparent;letter-spacing:-.02em;-webkit-background-clip:text;background-clip:text;font-family:Space Grotesk,sans-serif;font-size:1.75rem;font-weight:800}.logo span{opacity:.7;font-weight:400}.nav-links{align-items:center;gap:2rem;list-style:none;display:flex}.nav-links a{color:var(--text-secondary);transition:var(--transition-fast);font-size:.95rem;font-weight:500;position:relative}.nav-links a:after{content:"";background:var(--gradient-primary);width:0;height:2px;transition:var(--transition-normal);border-radius:2px;position:absolute;bottom:-4px;left:0}.nav-links a:hover{color:var(--text-primary)}.nav-links a:hover:after{width:100%}.nav-feedback-btn{color:var(--text-secondary);cursor:pointer;transition:var(--transition-fast);text-align:left;background:0 0;border:none;padding:0;font-size:.95rem;font-weight:500}.nav-feedback-btn:hover{color:var(--text-primary)}.nav-toggle{border:1px solid var(--border-glass);background:#ffffff0a;border-radius:9999px;flex-direction:column;justify-content:center;align-items:center;gap:4px;width:2.6rem;height:2.6rem;padding:0;display:none}.nav-toggle span{background:var(--text-primary);width:1.05rem;height:2px;transition:var(--transition-fast);border-radius:99px}.navbar.is-menu-open .nav-toggle span:first-child{transform:translateY(6px)rotate(45deg)}.navbar.is-menu-open .nav-toggle span:nth-child(2){opacity:0}.navbar.is-menu-open .nav-toggle span:nth-child(3){transform:translateY(-6px)rotate(-45deg)}.btn{transition:var(--transition-normal);border-radius:50px;justify-content:center;align-items:center;gap:.5rem;padding:.75rem 1.75rem;font-size:.95rem;font-weight:600;display:inline-flex;position:relative;overflow:hidden}.btn-primary{background:var(--gradient-btn);color:#fff;box-shadow:0 4px 20px #8b5cf64d}.btn-primary:hover{background:var(--gradient-btn-hover);transform:translateY(-2px);box-shadow:0 6px 30px #8b5cf680}.btn-primary:active{transform:translateY(0)}.btn-secondary{background:var(--bg-glass);color:var(--text-primary);border:1px solid var(--border-glass);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.btn-secondary:hover{background:var(--bg-card-hover);border-color:#fff3;transform:translateY(-2px)}.btn-icon{font-size:1.1em}.hero{text-align:center;background:var(--gradient-hero);justify-content:center;align-items:center;min-height:100vh;padding:6.15rem 1.5rem 4rem;display:flex;position:relative;overflow:hidden}.hero:after{content:"";pointer-events:none;z-index:5;background:radial-gradient(circle,#0000 30%,#0a0a1acc 100%);position:absolute;inset:0}.hero-carousel-bg{z-index:0;pointer-events:none;opacity:.3;filter:saturate(1.2)brightness(1.1);flex-direction:column;justify-content:center;gap:14px;display:flex;position:absolute;inset:0;overflow:hidden;transform:rotate(-4deg)scale(1.15);-webkit-mask-image:radial-gradient(90% 80%,#000000e6 0%,#0000 100%);mask-image:radial-gradient(90% 80%,#000000e6 0%,#0000 100%)}.carousel-row{flex-shrink:0;gap:14px;width:max-content;display:flex}.carousel-row img{object-fit:cover;border-radius:var(--radius-md);flex-shrink:0;width:220px;height:150px}.carousel-row.row-left{animation:50s linear infinite scrollLeft}.carousel-row.row-right{animation:55s linear infinite scrollRight}@keyframes scrollLeft{0%{transform:translate(0)}to{transform:translate(-50%)}}@keyframes scrollRight{0%{transform:translate(-50%)}to{transform:translate(0)}}.hero-content{z-index:1;max-width:1040px;position:relative}.hero-content-lowered{padding-top:0}.hero-badge{background:var(--bg-glass);border:1px solid var(--border-glass);color:var(--text-accent);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);animation:fadeInUp .8s var(--ease-out-expo);border-radius:50px;align-items:center;gap:.5rem;margin-bottom:2rem;padding:.5rem 1.25rem;font-size:.85rem;font-weight:500;display:inline-flex}.hero-badge .pulse{background:#22c55e;border-radius:50%;width:8px;height:8px;animation:2s ease-in-out infinite pulse}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.5)}}.hero h1{letter-spacing:-.04em;animation:fadeInUp .8s var(--ease-out-expo) .1s both;margin-bottom:.7rem;padding-top:0;font-family:Outfit,sans-serif;font-size:clamp(1.95rem,4vw,3.35rem);font-weight:800;line-height:1}.hero h1 .gradient-text{background:var(--gradient-primary);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.hero p{color:var(--text-secondary);max-width:560px;animation:fadeInUp .8s var(--ease-out-expo) .2s both;margin:0 auto 2.5rem;font-size:clamp(1.05rem,2vw,1.25rem);line-height:1.7}.hero-actions{animation:fadeInUp .8s var(--ease-out-expo) .3s both;flex-wrap:wrap;justify-content:center;align-items:center;gap:1rem;display:flex}.hero-puzzle-overlay{z-index:10;justify-content:center;align-items:center;width:100%;margin:0 auto;display:flex;position:relative}.hero-puzzle-container{border-radius:var(--radius-xl);z-index:20;width:66vw;max-width:1000px;animation:fadeInUp .8s var(--ease-out-expo) .2s both;background:#0f0c29;border:1px solid #8b5cf666;flex-direction:column;align-items:center;gap:2.5rem;margin:0 auto;padding:3rem;display:flex;position:relative;box-shadow:0 50px 100px -20px #000,0 0 40px #a855f759,0 0 90px #ec489940}.hero-puzzle-player{flex-direction:column;justify-content:center;align-items:center;gap:1.5rem;width:100%;display:flex}.hero-puzzle-stage{border-radius:calc(var(--radius-xl) - 8px);touch-action:none;background:radial-gradient(circle at top,#8b5cf61f,#0000 35%),linear-gradient(#181238fa,#0f0c29);width:100%;position:relative;overflow:hidden;box-shadow:inset 0 1px #ffffff0f,inset 0 -30px 80px #00000040}.hero-stage-stats{z-index:35;align-items:center;gap:.75rem;display:flex;position:absolute;top:1rem;right:1rem}.hero-stage-stats .game-stat{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);color:#ffffffe0;background:#0f0c29c7;border:1px solid #ffffff1a;border-radius:999px;padding:.45rem .75rem;box-shadow:0 10px 28px #00000038}.hero-puzzle-board-shell{background:#f5ebcb14;border:1px solid #ffffff24;border-radius:0;position:absolute;overflow:hidden;box-shadow:inset 0 0 0 1px #ffffff0a,0 18px 48px #04030d57}.hero-puzzle-hint{color:#ffffffdb;letter-spacing:-.01em;white-space:nowrap;opacity:0;pointer-events:none;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);z-index:35;background:#0f0c29e0;border:1px solid #ffffff1f;border-radius:999px;padding:.7rem 1rem;font-size:.9rem;font-weight:600;transition:opacity .35s,transform .35s;position:absolute;top:1rem;left:50%;transform:translate(-50%)translateY(-8px);box-shadow:0 10px 28px #00000042}.hero-puzzle-hint.active{opacity:1;transform:translate(-50%)translateY(0)}.hero-puzzle-reference{object-fit:cover;opacity:.2;filter:saturate(.9)contrast(.95);width:100%;height:100%;position:absolute;inset:0}.hero-board-cell{transition:var(--transition-fast);background:#ffffff06;border:1px dashed #ffffff17;position:absolute}.hero-board-cell.is-filled{cursor:default;background:0 0;border-color:#ffffff0a}.hero-board-cell.is-wrong{background:#ef444424;border-color:#ef444473}.hero-jigsaw-piece{transform-origin:50%;touch-action:none;-webkit-user-select:none;user-select:none;background:0 0;border:none;padding:0;transition:transform .18s,filter .18s,box-shadow .18s;position:absolute}.hero-jigsaw-piece img{object-fit:contain;pointer-events:none;width:100%;height:100%;display:block}.hero-jigsaw-piece.is-loose{cursor:grab;filter:drop-shadow(0 12px 14px #00000057)}.hero-jigsaw-piece.is-loose:hover{filter:drop-shadow(0 16px 18px #0000006b)}.hero-jigsaw-piece.is-dragging{cursor:grabbing;filter:drop-shadow(0 0 16px #ec489947)drop-shadow(0 18px 22px #0000007a);transform:scale(1.03)rotate(0)!important}.hero-jigsaw-piece.is-placed{cursor:default;filter:drop-shadow(0 10px 10px #00000038)}.hero-congrats-burst{color:#fff;opacity:0;pointer-events:none;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);z-index:36;background:#0f0c29c7;border:1px solid #ffffff29;border-radius:22px;flex-direction:column;align-items:center;gap:.3rem;padding:1rem 1.4rem;transition:opacity .3s,transform .3s;display:flex;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)scale(.88);box-shadow:0 18px 40px #00000059,0 0 36px #ec489947,0 0 72px #a855f73d}.hero-congrats-burst.active{opacity:1;transform:translate(-50%,-50%)scale(1)}.hero-congrats-kicker{text-transform:uppercase;letter-spacing:.08em;color:#ffffffb8;font-size:.78rem;font-weight:700}.hero-congrats-burst strong{background:var(--gradient-primary);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:1.45rem;line-height:1.05}.hero-win-banner{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#0f0c29e0;border:1px solid #ffffff1f;border-radius:18px;justify-content:space-between;align-items:center;gap:1rem;padding:.85rem 1rem;display:none;position:absolute;inset:auto 1rem 1rem}.hero-win-banner.active{display:flex}.hero-win-overlay{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#0a0a1ad6;border-radius:0}.hero-win-overlay .win-actions{justify-content:center}.game-stats-row{color:var(--text-primary);text-align:center;flex-wrap:wrap;justify-content:center;gap:1rem;width:100%;font-size:.95rem;font-weight:500;display:flex}.hero-decoration{pointer-events:none;z-index:0;width:100%;height:100%;position:absolute;top:0;left:0}.floating-piece{opacity:.15;font-size:2.5rem;animation:15s ease-in-out infinite floatPiece,4s ease-in-out infinite alternate pulseLight;position:absolute}@keyframes pulseLight{0%{filter:brightness()}to{filter:brightness(1.5)drop-shadow(0 0 10px #fff6)}}.floating-piece:first-child{animation-delay:0s;top:15%;left:8%}.floating-piece:nth-child(2){font-size:2rem;animation-delay:-3s;top:25%;right:12%}.floating-piece:nth-child(3){font-size:3rem;animation-delay:-7s;bottom:20%;left:15%}.floating-piece:nth-child(4){font-size:1.8rem;animation-delay:-11s;bottom:30%;right:8%}.floating-piece:nth-child(5){font-size:2.2rem;animation-delay:-5s;top:50%;left:5%}@keyframes floatPiece{0%,to{transform:translateY(0)rotate(0)}33%{transform:translateY(-20px)rotate(10deg)}66%{transform:translateY(10px)rotate(-5deg)}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.section-header{text-align:center;margin-bottom:3.5rem}.section-header h2{letter-spacing:-.03em;margin-bottom:.75rem;font-family:Space Grotesk,sans-serif;font-size:clamp(2rem,4vw,2.75rem);font-weight:700}.section-header p{color:var(--text-secondary);max-width:500px;margin:0 auto;font-size:1.1rem}.gallery-section{padding:var(--section-gap) 0}.puzzle-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem;display:grid}.puzzle-card{border-radius:var(--radius-lg);background:var(--bg-card);border:1px solid var(--border-glass);transition:var(--transition-normal);cursor:pointer;position:relative;overflow:hidden}.puzzle-card:hover{box-shadow:var(--shadow-glow-strong);border-color:#8b5cf64d;transform:translateY(-6px)}.puzzle-card-image{aspect-ratio:1;object-fit:cover;width:100%;transition:var(--transition-slow)}.puzzle-card:hover .puzzle-card-image{transform:scale(1.05)}.puzzle-card-overlay{opacity:0;transition:var(--transition-normal);background:linear-gradient(#0000 0%,#0003 60%,#000000d9 100%);flex-direction:column;justify-content:flex-end;padding:1.5rem;display:flex;position:absolute;inset:0}.puzzle-card:hover .puzzle-card-overlay{opacity:1}.puzzle-card-title{margin-bottom:.4rem;font-family:Space Grotesk,sans-serif;font-size:1.2rem;font-weight:700}.puzzle-card-meta{color:var(--text-secondary);margin-bottom:1rem;font-size:.85rem}.puzzle-card-actions{justify-content:space-between;align-items:center;gap:.75rem;display:flex}.card-action-group{gap:.5rem;display:flex}.puzzle-card-actions .btn{padding:.5rem 1rem;font-size:.8rem}.upvote-container{align-items:center;display:flex}.upvote-btn{color:var(--text-primary);transition:all .3s var(--ease-out-expo);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#ffffff14;border:1px solid #ffffff1a;border-radius:50px;align-items:center;gap:.4rem;padding:.4rem .8rem;font-size:.85rem;font-weight:600;display:flex}.upvote-btn:hover{background:#ffffff26;border-color:#ffffff4d;transform:scale(1.05)}.upvote-btn.voted{color:#f472b6;background:#ec489926;border-color:#ec489966}.heart-icon{font-size:1rem;transition:transform .3s cubic-bezier(.175,.885,.32,1.275)}.upvote-btn:active .heart-icon{transform:scale(1.4)}.upvote-count{font-variant-numeric:tabular-nums}.upload-section{padding:var(--section-gap) 0}.upload-area{border-radius:var(--radius-xl);text-align:center;background:var(--bg-card);transition:var(--transition-normal);cursor:pointer;border:2px dashed #8b5cf64d;padding:4rem 2rem;position:relative;overflow:hidden}.upload-area:before{content:"";background:var(--gradient-primary);opacity:0;transition:var(--transition-normal);position:absolute;inset:0}.upload-area:hover{background:var(--bg-card-hover);border-color:#8b5cf699}.upload-area:hover:before{opacity:.03}.upload-area.drag-over{background:#8b5cf614;border-color:#8b5cf6}.upload-area.drag-over:before{opacity:.08}.upload-icon{z-index:1;margin-bottom:1.5rem;font-size:3.5rem;display:block;position:relative}.upload-area h3{z-index:1;margin-bottom:.5rem;font-family:Space Grotesk,sans-serif;font-size:1.5rem;font-weight:700;position:relative}.upload-area p{color:var(--text-secondary);z-index:1;font-size:.95rem;position:relative}.upload-area .browse-link{color:var(--text-accent);text-underline-offset:3px;font-weight:600;text-decoration:underline}#upload-input{display:none}.upload-preview-card{text-align:center;background:#ffffff0a;border:1px solid #ffffff1a;border-radius:22px;max-width:620px;margin:0 auto;padding:1.5rem;box-shadow:0 20px 50px #0000002e}.upload-preview-image{aspect-ratio:1;object-fit:cover;border:1px solid #ffffff1f;border-radius:18px;width:min(100%,320px);margin:0 auto 1rem;box-shadow:0 10px 24px #00000042}.upload-preview-copy{flex-direction:column;align-items:center;gap:.65rem;margin-bottom:1.25rem;display:flex}.upload-preview-copy p{color:var(--text-secondary);max-width:420px}.upload-preview-pill{letter-spacing:.03em;text-transform:uppercase;color:var(--text-primary);background:#ec489924;border:1px solid #ec489938;border-radius:999px;justify-content:center;align-items:center;padding:.4rem .75rem;font-size:.78rem;font-weight:700;display:inline-flex}.upload-preview-fields{flex-direction:column;align-items:center;gap:.9rem;display:flex}.upload-text-input{color:#fff;background:#00000047;border:1px solid #ffffff2e;border-radius:12px;outline:none;width:min(100%,320px);padding:.85rem 1rem}.upload-checkbox-row{color:var(--text-secondary);cursor:pointer;align-items:center;gap:.6rem;display:flex}.upload-preview-actions{flex-wrap:wrap;justify-content:center;gap:.9rem;margin-top:1.4rem;display:flex}.crop-modal-overlay{z-index:360}.crop-modal-shell{background:linear-gradient(#1a153af5,#0e0c26fa);border:1px solid #ffffff1a;width:min(92vw,780px);padding:1.5rem;box-shadow:0 40px 80px #0000006b,0 0 40px #8b5cf62e}.crop-modal-header{text-align:center;margin-bottom:1.25rem}.crop-modal-header p{color:var(--text-secondary);margin-top:.35rem}.crop-workspace{flex-direction:column;align-items:center;gap:1.1rem;display:flex}.crop-stage{background:#ffffff08;border:1px solid #ffffff14;border-radius:28px;width:min(100%,620px);min-height:470px;position:relative;overflow:hidden}.crop-backdrop{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:radial-gradient(circle at top,#8b5cf633,#0000 38%),#06050fb8;position:absolute;inset:0}.crop-frame{cursor:grab;border-radius:24px;width:380px;height:380px;position:absolute;top:50%;left:50%;overflow:hidden;transform:translate(-50%,-50%);box-shadow:0 0 0 999px #05040c70,inset 0 0 0 1px #ffffff14}.crop-frame:active{cursor:grabbing}.crop-image{-webkit-user-select:none;user-select:none;pointer-events:none;max-width:none;position:absolute}.crop-frame-border{pointer-events:none;border:1.5px solid #ffffffbf;border-radius:24px;position:absolute;inset:0;box-shadow:inset 0 0 0 1px #ffffff1f,0 0 20px #ffffff14}.crop-controls{background:#ffffff0a;border:1px solid #ffffff14;border-radius:18px;width:min(100%,460px);padding:.95rem 1rem}.crop-zoom-label{color:var(--text-primary);justify-content:space-between;align-items:center;margin-bottom:.7rem;font-size:.95rem;display:flex}.crop-zoom-slider{accent-color:#ec4899;width:100%}.crop-actions{flex-wrap:wrap;justify-content:center;gap:.9rem;margin-top:1.2rem;display:flex}.modal-overlay{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:200;opacity:0;background:#000000d9;justify-content:center;align-items:center;padding:1.5rem;transition:opacity .3s;display:none;position:fixed;inset:0}.modal-overlay.active{opacity:1;display:flex}.modal-content{background:var(--bg-secondary);border:1px solid var(--border-glass);border-radius:var(--radius-xl);width:100%;max-width:960px;max-height:95vh;animation:modalAppear .4s var(--ease-out-expo);padding:2rem;position:relative;overflow-y:auto}@keyframes modalAppear{0%{opacity:0;transform:scale(.9)translateY(30px)}to{opacity:1;transform:scale(1)translateY(0)}}.modal-close{background:var(--bg-glass);border:1px solid var(--border-glass);width:40px;height:40px;color:var(--text-primary);transition:var(--transition-fast);z-index:10;border-radius:50%;justify-content:center;align-items:center;font-size:1.2rem;display:flex;position:absolute;top:1rem;right:1rem}.modal-close:hover{background:var(--bg-card-hover);transform:rotate(90deg)}.modal-header{justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-right:3rem;display:flex}.modal-header h2{font-family:Space Grotesk,sans-serif;font-size:1.5rem;font-weight:700}.game-stats{align-items:center;gap:1.5rem;display:flex}.game-stat{color:var(--text-secondary);align-items:center;gap:.4rem;font-size:.9rem;display:flex}.game-stat .stat-icon{font-size:1.1rem}.game-stat .stat-value{color:var(--text-primary);font-variant-numeric:tabular-nums;font-weight:700}.difficulty-selector{justify-content:center;gap:.5rem;margin-bottom:1.5rem;display:flex}.diff-btn{background:var(--bg-glass);color:var(--text-secondary);border:1px solid var(--border-glass);transition:var(--transition-fast);border-radius:50px;padding:.5rem 1.25rem;font-size:.85rem;font-weight:600}.diff-btn:hover{background:var(--bg-card-hover);color:var(--text-primary)}.diff-btn.active{background:var(--gradient-btn);color:#fff;border-color:#0000}.puzzle-game-area{justify-content:center;align-items:flex-start;gap:1.5rem;display:flex}.modal-puzzle-stage{border-radius:var(--radius-lg);touch-action:none;background:radial-gradient(circle at top,#8b5cf61f,#0000 35%),linear-gradient(#181238fa,#0f0c29);width:min(100%,960px);position:relative;overflow:hidden;box-shadow:inset 0 1px #ffffff0f,inset 0 -30px 80px #00000040}.modal-puzzle-board-shell{background:#f5ebcb14;border:1px solid #ffffff24;border-radius:0;position:absolute;overflow:hidden;box-shadow:inset 0 0 0 1px #ffffff0a,0 18px 48px #04030d57}.modal-puzzle-reference{object-fit:cover;opacity:.22;filter:saturate(.9)contrast(.95);width:100%;height:100%;position:absolute;inset:0}.modal-board-cell{transition:var(--transition-fast);background:#ffffff06;border:1px dashed #ffffff17;position:absolute}.modal-board-cell.is-filled{background:0 0;border-color:#ffffff0a}.modal-jigsaw-piece{transform-origin:50%;touch-action:none;-webkit-user-select:none;user-select:none;background:0 0;border:none;padding:0;transition:transform .18s,filter .18s,box-shadow .18s;position:absolute}.modal-jigsaw-piece img{object-fit:contain;pointer-events:none;width:100%;height:100%;display:block}.modal-jigsaw-piece.is-loose{cursor:grab;filter:drop-shadow(0 12px 14px #00000057)}.modal-jigsaw-piece.is-loose:hover{filter:drop-shadow(0 16px 18px #0000006b)}.modal-jigsaw-piece.is-dragging{cursor:grabbing;filter:drop-shadow(0 0 16px #ec489947)drop-shadow(0 18px 22px #0000007a);transform:scale(1.03)rotate(0)!important}.modal-jigsaw-piece.is-placed{cursor:default;filter:drop-shadow(0 10px 10px #00000038)}.modal-puzzle-hint{color:#ffffffdb;letter-spacing:-.01em;white-space:nowrap;opacity:0;pointer-events:none;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);z-index:35;background:#0f0c29e0;border:1px solid #ffffff1f;border-radius:999px;padding:.7rem 1rem;font-size:.9rem;font-weight:600;transition:opacity .35s,transform .35s;position:absolute;top:1rem;left:50%;transform:translate(-50%)translateY(-8px);box-shadow:0 10px 28px #00000042}.modal-puzzle-hint.active{opacity:1;transform:translate(-50%)translateY(0)}.modal-congrats-burst{color:#fff;opacity:0;pointer-events:none;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);z-index:36;background:#0f0c29c7;border:1px solid #ffffff29;border-radius:22px;flex-direction:column;align-items:center;gap:.3rem;padding:1rem 1.4rem;transition:opacity .3s,transform .3s;display:flex;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)scale(.88);box-shadow:0 18px 40px #00000059,0 0 36px #ec489947,0 0 72px #a855f73d}.modal-congrats-burst.active{opacity:1;transform:translate(-50%,-50%)scale(1)}.modal-congrats-kicker{text-transform:uppercase;letter-spacing:.08em;color:#ffffffb8;font-size:.78rem;font-weight:700}.modal-congrats-burst strong{background:var(--gradient-primary);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:1.45rem;line-height:1.05}.puzzle-reference{flex-shrink:0;width:160px}.puzzle-reference img{border-radius:var(--radius-md);border:1px solid var(--border-glass);opacity:.7;width:100%;transition:var(--transition-fast)}.puzzle-reference img:hover{opacity:1}.puzzle-reference p{color:var(--text-muted);text-align:center;margin-top:.5rem;font-size:.8rem}.win-overlay{z-index:50;border-radius:var(--radius-md);background:#0a0a1ae6;flex-direction:column;justify-content:center;align-items:center;animation:.5s fadeIn;display:none;position:absolute;inset:0}.win-overlay.active{display:flex}.win-overlay .trophy{margin-bottom:1rem;font-size:4rem;animation:1s infinite bounce}.win-overlay h3{background:var(--gradient-primary);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:.5rem;font-family:Space Grotesk,sans-serif;font-size:1.8rem;font-weight:800}.win-overlay p{color:var(--text-secondary);margin-bottom:1.5rem}.win-overlay .win-actions{gap:.75rem;display:flex}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.how-section{padding:var(--section-gap) 0}.steps-grid{grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:2rem;display:grid}.step-card{background:var(--bg-card);border:1px solid var(--border-glass);border-radius:var(--radius-lg);text-align:center;transition:var(--transition-normal);padding:2rem;position:relative}.step-card:hover{background:var(--bg-card-hover);border-color:#8b5cf64d;transform:translateY(-4px)}.step-number{background:var(--gradient-btn);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:48px;height:48px;margin:0 auto 1.25rem;font-family:Space Grotesk,sans-serif;font-size:1.2rem;font-weight:700;display:flex}.step-card h3{margin-bottom:.5rem;font-family:Space Grotesk,sans-serif;font-size:1.15rem;font-weight:700}.step-card p{color:var(--text-secondary);font-size:.9rem}.share-modal-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:300;background:#000000b3;justify-content:center;align-items:center;padding:1.5rem;display:none;position:fixed;inset:0}.share-modal-overlay.active{display:flex}.share-modal{background:var(--bg-secondary);border:1px solid var(--border-glass);border-radius:var(--radius-xl);text-align:center;width:100%;max-width:460px;animation:modalAppear .4s var(--ease-out-expo);padding:2.5rem}.share-modal h3{margin-bottom:.5rem;font-family:Space Grotesk,sans-serif;font-size:1.4rem;font-weight:700}.share-modal p{color:var(--text-secondary);margin-bottom:1.5rem;font-size:.9rem}.share-link-box{gap:.5rem;margin-bottom:1.5rem;display:flex}.share-link-box input{background:var(--bg-card);border:1px solid var(--border-glass);border-radius:var(--radius-sm);color:var(--text-primary);transition:var(--transition-fast);outline:none;flex:1;padding:.75rem 1rem;font-family:Outfit,sans-serif;font-size:.85rem}.share-link-box input:focus{border-color:#8b5cf6}.share-link-box .btn-copy{border-radius:var(--radius-sm);background:var(--gradient-btn);color:#fff;white-space:nowrap;transition:var(--transition-fast);padding:.75rem 1.25rem;font-size:.85rem;font-weight:600}.share-link-box .btn-copy:hover{transform:translateY(-1px);box-shadow:0 4px 15px #8b5cf64d}.share-socials{justify-content:center;gap:.75rem;display:flex}.share-socials button{background:var(--bg-glass);border:1px solid var(--border-glass);width:48px;height:48px;color:var(--text-primary);transition:var(--transition-fast);border-radius:50%;justify-content:center;align-items:center;font-size:1.2rem;display:flex}.share-socials button:hover{background:var(--bg-card-hover);transform:translateY(-2px)}.share-close{color:var(--text-muted);transition:var(--transition-fast);background:0 0;margin-top:1.5rem;font-size:.85rem}.share-close:hover{color:var(--text-primary)}.footer{border-top:1px solid var(--border-glass);text-align:center;padding:3rem 0}.footer p{color:var(--text-muted);font-size:.85rem}.footer .logo{margin-bottom:.5rem;font-size:1.3rem;display:inline-block}.toast{background:var(--bg-secondary);border:1px solid var(--border-glass);color:var(--text-primary);z-index:400;opacity:0;transition:all .4s var(--ease-out-expo);border-radius:50px;align-items:center;gap:.5rem;padding:.85rem 1.5rem;font-size:.9rem;font-weight:500;display:flex;position:fixed;bottom:2rem;left:50%;transform:translate(-50%)translateY(100px);box-shadow:0 8px 32px #0006}.toast.show{opacity:1;transform:translate(-50%)translateY(0)}@media (max-width:768px){:root{--section-gap:4rem}.navbar .container{position:relative}.nav-toggle{display:inline-flex}.nav-links{border:1px solid var(--border-glass);-webkit-backdrop-filter:blur(16px);background:#0a0a1aeb;border-radius:16px;flex-direction:column;gap:.35rem;padding:.75rem;display:none;position:absolute;top:calc(100% + .8rem);left:1.5rem;right:1.5rem;box-shadow:0 12px 40px #00000059}.nav-links.is-open{display:flex}.nav-links li{width:100%}.nav-links a,.nav-feedback-btn{border-radius:10px;width:100%;padding:.7rem .85rem;display:block}.nav-links a:after{display:none}.nav-links a:hover,.nav-feedback-btn:hover{background:#ffffff14}.hero h1{font-size:clamp(2.2rem,8vw,3.5rem)}.puzzle-grid{grid-template-columns:repeat(auto-fill,minmax(250px,1fr))}.modal-content{padding:1.25rem}.puzzle-board-wrapper{flex-direction:column;align-items:center}.puzzle-reference{order:2;width:100px}.modal-puzzle-stage{width:100%}.game-stats{flex-wrap:wrap;gap:.75rem}.steps-grid{grid-template-columns:1fr}.hero-puzzle-container{width:100%;padding:1.25rem}.hero-puzzle-stage{border-radius:20px}.hero-stage-stats{flex-wrap:wrap;justify-content:flex-end;gap:.5rem;max-width:calc(100% - 1.6rem);top:.8rem;right:.8rem}.hero-stage-stats .game-stat{padding:.42rem .68rem;font-size:.82rem}.crop-modal-shell{width:min(94vw,680px);padding:1.1rem}.crop-stage{min-height:420px}.crop-frame{width:min(78vw,340px);height:min(78vw,340px)}}@media (max-width:480px){.hero-actions{flex-direction:column;width:100%}.hero-actions .btn{width:100%}.difficulty-selector{flex-wrap:wrap}.hero-puzzle-container{padding:1rem}.hero-stage-stats{left:.75rem;right:.75rem}.hero-stage-stats .game-stat{font-size:.78rem}.upload-preview-card{padding:1.1rem}.crop-stage{min-height:360px}.crop-frame{border-radius:20px;width:min(82vw,280px);height:min(82vw,280px)}.crop-frame-border{border-radius:20px}}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--bg-primary)}::-webkit-scrollbar-thumb{background:#8b5cf64d;border-radius:10px}::-webkit-scrollbar-thumb:hover{background:#8b5cf680}#confetti-canvas{z-index:500;pointer-events:none;position:fixed;inset:0}
