@keyframes points-glow-pulse{0%{opacity:0;transform:scale(.3)}30%{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(1.6)}}@keyframes coin-burst{0%{opacity:0;transform:scale(0) translate(0,0)}15%{opacity:1;transform:scale(1.1) translate(0,0)}40%{opacity:1;transform:scale(1) translate(var(--coin-x),var(--coin-y))}to{opacity:0;transform:scale(.6) translate(calc(var(--coin-x)*1.3),calc(var(--coin-y)*1.3))}}@keyframes badge-pop{0%{opacity:0;transform:scale(0)}60%{opacity:1;transform:scale(1.12)}to{opacity:1;transform:scale(1)}}@keyframes coin-land-pulse{0%{transform:scale(1);box-shadow:0 0 0 0 rgba(251,191,36,.5)}30%{transform:scale(1.2);box-shadow:0 0 12px 4px rgba(251,191,36,.4)}60%{transform:scale(.95)}to{transform:scale(1);box-shadow:0 0 0 0 transparent}}@keyframes streak-toast-in{0%{opacity:0;transform:translateX(-50%) translateY(-20px) scale(.8)}to{opacity:1;transform:translateX(-50%) translateY(0) scale(1)}}@keyframes streak-toast-out{0%{opacity:1;transform:translateX(-50%) translateY(0) scale(1)}to{opacity:0;transform:translateX(-50%) translateY(-20px) scale(.8)}}@keyframes rank-tier-grow{0%{opacity:0;transform:translate(-50%,-50%) scale(0)}50%{opacity:1;transform:translate(-50%,-50%) scale(1.1)}70%{transform:translate(-50%,-50%) scale(.95)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}@keyframes pulse-grid{0%,to{opacity:.4;transform:scale(.95)}50%{opacity:1;transform:scale(1)}}@keyframes piece-snap{0%{transform:scale(1.12);filter:drop-shadow(0 0 14px rgba(99,102,241,.4)) drop-shadow(0 0 4px rgba(99,102,241,.2)) drop-shadow(0 1px 0 rgba(0,0,0,.15))}40%{transform:scale(.96)}70%{transform:scale(1.02)}to{transform:scale(1);filter:drop-shadow(0 .5px 0 rgba(0,0,0,.1)) drop-shadow(0 0 .3px rgba(0,0,0,.12)) drop-shadow(-.3px -.3px 0 rgba(255,255,255,.2))}}@keyframes mp-suggestion-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes mp-name-modal-in{0%{opacity:0}to{opacity:1}}@keyframes ws-pulse{0%,to{opacity:1;box-shadow:0 0 4px #4ade80}50%{opacity:.4;box-shadow:0 0 8px #4ade80}}@keyframes community-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.6)}}@keyframes community-glow-shift{0%,to{opacity:.4;transform:translate(-30%,-30%) scale(1)}50%{opacity:.6;transform:translate(-50%,-50%) scale(1.2)}}@keyframes community-bar-shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes spin{to{transform:rotate(360deg)}}html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body,html{overflow-x:hidden}::selection{background:#c7d2fe;color:#1e1b4b}.site-container{max-width:80rem;margin-left:auto;margin-right:auto;padding-left:1rem;padding-right:1rem}@media (min-width:640px){.site-container{padding-left:1.5rem;padding-right:1.5rem}}@media (min-width:1024px){.site-container{padding-left:2rem;padding-right:2rem}}@media (max-width:768px){.breadcrumb-nav{overflow-x:auto;white-space:nowrap;-webkit-overflow-scrolling:touch;scrollbar-width:none}.breadcrumb-nav::-webkit-scrollbar{display:none}}.puzzle-overlay{display:none;position:absolute;inset:0;z-index:1;pointer-events:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cpath d='M60 0v25l2,2a6,6 0 1,0 0,6l-2,2v25h-25l-2,2a6,6 0 1,1-6,0l-2,-2H0V0h60zM120 0v60h-25l-2,2a6,6 0 1,1-6,0l-2,-2H60V35l2,-2a6,6 0 1,1 0,-6l-2,-2V0h60zM60 60v25l2,2a6,6 0 1,0 0,6l-2,2v25H0V60h25l2,2a6,6 0 1,0 6,0l2,-2h25zM120 60v60H60V95l2,-2a6,6 0 1,1 0,-6l-2,-2V60h25l2,2a6,6 0 1,0 6,0l2,-2h25z' fill='none' stroke='%23ffffff' stroke-width='1.5' stroke-opacity='0.25'/%3E%3C/svg%3E");--puzzle-cols:3;--puzzle-rows:3;background-size:calc(200%/var(--puzzle-cols)) calc(200%/var(--puzzle-rows))}.bg-pattern-dots{background-image:url("data:image/svg+xml,<svg xmlns=%22http://www.w3.org/2000/svg%22 width=%2220%22 height=%2220%22><circle cx=%2210%22 cy=%2210%22 r=%221%22 fill=%22white%22/></svg>");background-size:20px 20px}.bg-pattern-grid{background-image:url("data:image/svg+xml,<svg xmlns=%22http://www.w3.org/2000/svg%22 width=%2240%22 height=%2240%22><rect width=%2240%22 height=%2240%22 fill=%22none%22 stroke=%22white%22 stroke-width=%220.5%22/></svg>");background-size:40px 40px}.bg-pattern-grid-lg{background-image:url("data:image/svg+xml,<svg xmlns=%22http://www.w3.org/2000/svg%22 width=%2260%22 height=%2260%22><rect width=%2260%22 height=%2260%22 fill=%22none%22 stroke=%22white%22 stroke-width=%220.5%22/></svg>");background-size:60px 60px}.sticky-toolbar{position:sticky;top:65px;z-index:30}.select-arrow{background-image:url("data:image/svg+xml,<svg xmlns=%22http://www.w3.org/2000/svg%22 width=%2216%22 height=%2216%22 fill=%22%236b7280%22 viewBox=%220 0 16 16%22><path d=%22M4.646 6.646a.5.5 0 01.708 0L8 9.293l2.646-2.647a.5.5 0 01.708.708l-3 3a.5.5 0 01-.708 0l-3-3a.5.5 0 010-.708z%22/></svg>");background-repeat:no-repeat;background-position:right 8px center}.cat-filter-btn,.puzzles-filter-btn{background:#f3f4f6;color:#4b5563;border:1px solid transparent}.cat-filter-btn:hover,.puzzles-filter-btn:hover{background:#e5e7eb;color:#1f2937}.cat-filter-btn.active,.puzzles-filter-btn.active{background:#eef2ff;color:#4338ca;border-color:#c7d2fe}.puzzle-card-hidden{display:none}.puzzle-card.completed .puzzle-card-completed-badge{display:flex}.points-earned-center{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);z-index:10000;pointer-events:none;display:flex;align-items:center;justify-content:center;width:0;height:0}.points-glow-ring{position:absolute;width:160px;height:160px;border-radius:50%;background:radial-gradient(circle,rgba(251,191,36,.35) 0,rgba(251,191,36,0) 70%);opacity:0;transform:scale(.3)}.points-glow-ring--animate{animation:points-glow-pulse 1.4s ease-out forwards}.points-coin{position:absolute;width:18px;height:18px;border-radius:50%;background:linear-gradient(135deg,#fbbf24 0,#f59e0b 50%,#d97706 100%);box-shadow:0 0 8px rgba(251,191,36,.5),inset 0 -2px 3px rgba(0,0,0,.15),inset 0 2px 3px rgba(255,255,255,.3);opacity:0;transform:scale(0)}.points-coin::after,.points-fly-coin::after{content:"";position:absolute;border-radius:50%}.points-coin::after{top:3px;left:4px;width:6px;height:4px;background:rgba(255,255,255,.45)}.points-coin--burst{animation:coin-burst 1s ease-out var(--coin-delay, 0s) forwards}.points-earned-badge{position:absolute;display:flex;align-items:center;justify-content:center;min-width:80px;padding:12px 24px;border-radius:20px;background:linear-gradient(135deg,#fbbf24 0,#f59e0b 40%,#d97706 100%);color:#fff;font-size:2rem;font-weight:900;font-family:"Inter",system-ui,sans-serif;letter-spacing:-.02em;text-shadow:0 2px 4px rgba(0,0,0,.2);box-shadow:0 4px 24px rgba(251,191,36,.5),0 2px 8px rgba(0,0,0,.15),inset 0 1px 2px rgba(255,255,255,.3);opacity:0;transform:scale(0);white-space:nowrap}.points-earned-badge--animate{animation:badge-pop .5s cubic-bezier(.34,1.56,.64,1) forwards}.points-fly-badge,.points-fly-coin{position:fixed;top:0;left:0;z-index:10001;pointer-events:none;will-change:transform,opacity}.points-fly-badge{display:flex;align-items:center;justify-content:center;min-width:60px;padding:8px 18px;border-radius:16px;background:linear-gradient(135deg,#fbbf24 0,#f59e0b 40%,#d97706 100%);color:#fff;font-size:1.5rem;font-weight:900;font-family:"Inter",system-ui,sans-serif;letter-spacing:-.02em;text-shadow:0 2px 4px rgba(0,0,0,.2);box-shadow:0 4px 20px rgba(251,191,36,.45),0 2px 6px rgba(0,0,0,.12);white-space:nowrap}.points-fly-coin{width:14px;height:14px;border-radius:50%;background:linear-gradient(135deg,#fbbf24 0,#f59e0b 50%,#d97706 100%);box-shadow:0 0 6px rgba(251,191,36,.5),inset 0 -1px 2px rgba(0,0,0,.15)}.points-fly-coin::after{top:2px;left:3px;width:5px;height:3px;background:rgba(255,255,255,.4)}.user-bar__points--coin-landed{animation:coin-land-pulse .5s ease-out}.user-bar__points--counting{background-color:#fffbeb}.user-bar__points-value--counting{color:#b45309}.streak-celebration-toast{position:fixed;top:80px;left:50%;transform:translateX(-50%);z-index:10002;display:flex;align-items:center;gap:10px;padding:12px 24px;border-radius:16px;background:linear-gradient(135deg,#ff9800,#ff5722);color:#fff;font-family:"Inter",system-ui,sans-serif;font-size:.95rem;font-weight:600;box-shadow:0 8px 30px rgba(255,87,34,.35),0 2px 8px rgba(0,0,0,.1);white-space:nowrap;pointer-events:none}.streak-celebration-toast--enter{animation:streak-toast-in .5s cubic-bezier(.34,1.56,.64,1) forwards}.streak-celebration-toast--leave{animation:streak-toast-out .6s ease-in forwards}.streak-celebration-toast__icon{font-size:1.3rem;line-height:1}.streak-celebration-toast__text{display:flex;align-items:center;gap:8px}.streak-celebration-toast__title{font-weight:800}.streak-celebration-toast__pts{opacity:.9;font-weight:500}.rank-tier-celebration{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%) scale(0);z-index:10003;pointer-events:none;display:flex;flex-direction:column;align-items:center;gap:12px;opacity:0}.rank-tier-celebration--animate{animation:rank-tier-grow 1.2s cubic-bezier(.34,1.56,.64,1) forwards}.rank-tier-celebration__icon{width:96px;height:96px;filter:drop-shadow(0 4px 20px rgba(99,102,241,.4))}.rank-tier-celebration__label{font-size:1.1rem;font-weight:700;color:#4f46e5;text-shadow:0 1px 4px rgba(0,0,0,.1)}.rank-tier-fly{position:fixed;top:0;left:0;z-index:10003;pointer-events:none;will-change:transform,opacity}.rank-tier-fly__icon{width:64px;height:64px;filter:drop-shadow(0 2px 12px rgba(99,102,241,.35))}@media (prefers-reduced-motion:reduce){.points-coin--burst,.points-earned-badge--animate,.points-glow-ring--animate,.rank-tier-celebration--animate,.streak-celebration-toast--enter,.streak-celebration-toast--leave,.user-bar__points--coin-landed{animation:none;opacity:1;transform:none}.points-earned-badge--animate{transform:scale(1)}.streak-celebration-toast--enter{transform:translateX(-50%)}}.puzzle-table{background:repeating-linear-gradient(90deg,transparent,transparent 200px,rgba(0,0,0,.008) 200px,rgba(0,0,0,.008) 201px),repeating-linear-gradient(0deg,transparent,transparent 200px,rgba(0,0,0,.006) 200px,rgba(0,0,0,.006) 201px),radial-gradient(ellipse at 50% 0,rgba(255,255,255,.8) 0,transparent 50%),linear-gradient(170deg,#f1f0ee 0,#e9e7e4 25%,#e4e2df 55%,#eae8e5 85%,#f0eeeb 100%);min-height:70vh}.puzzle-table-texture{background-image:url("data:image/svg+xml,<svg xmlns=%22http://www.w3.org/2000/svg%22 width=%22200%22 height=%22200%22><filter id=%22f%22><feTurbulence type=%22fractalNoise%22 baseFrequency=%220.9%22 numOctaves=%224%22 stitchTiles=%22stitch%22/><feColorMatrix type=%22saturate%22 values=%220%22/></filter><rect width=%22200%22 height=%22200%22 filter=%22url(%23f)%22 opacity=%220.025%22/></svg>")}.board,.slot{position:relative}.board{display:grid;background:linear-gradient(135deg,#ede7db 0,#f7f2ea 40%,#ede7db 80%,#e8e0d4 100%);border-radius:2px}.slot{border:1px dashed rgba(0,0,0,.1);box-sizing:border-box;transition:background .2s,border-color .2s,box-shadow .2s}.slot.filled{border-color:transparent}.slot.highlight{background:rgba(99,102,241,.08);border-color:rgba(99,102,241,.4);box-shadow:inset 0 0 12px rgba(99,102,241,.08)}.board-border{border:6px solid #b8a48a;border-radius:8px;overflow:hidden;display:inline-block;background:linear-gradient(135deg,#f5f2ed 0,#faf8f5 100%);box-shadow:inset 0 2px 4px rgba(0,0,0,.06),0 4px 16px rgba(0,0,0,.1),0 1px 4px rgba(0,0,0,.06)}.board-border::before,.piece::after{content:"";position:absolute;pointer-events:none}.board-border::before{inset:-6px;border:6px solid transparent;border-image:repeating-linear-gradient(90deg,#b8a48a 0,#c4b29a 2px,#b8a48a 4px,#ae9a80 7px,#b8a48a 9px,#c4b29a 11px) 6;z-index:1}.puzzle-board-container{position:relative;overflow:visible}.puzzle-pieces-9 .puzzle-board-container{--puzzle-board-max-width:360px;width:360px;max-width:100%}.puzzle-pieces-16 .puzzle-board-container{--puzzle-board-max-width:480px;width:480px;max-width:100%}.puzzle-pieces-25 .puzzle-board-container{--puzzle-board-max-width:520px;width:520px;max-width:100%}.puzzle-pieces-49 .puzzle-board-container{--puzzle-board-max-width:600px;width:600px;max-width:100%}.puzzle-pieces-100 .puzzle-board-container{--puzzle-board-max-width:700px;width:700px;max-width:100%}.puzzle-pieces-225 .puzzle-board-container{--puzzle-board-max-width:800px;width:800px;max-width:100%}.puzzle-pieces-500 .puzzle-board-container{--puzzle-board-max-width:900px;width:900px;max-width:100%}.piece{position:relative;cursor:grab;user-select:none;-webkit-user-select:none;touch-action:none;border-radius:0;transition:filter .18s ease,transform .18s ease;filter:drop-shadow(0 1.5px 0 rgba(0,0,0,.25)) drop-shadow(0 0 .5px rgba(0,0,0,.35)) drop-shadow(2px 4px 6px rgba(0,0,0,.18)) drop-shadow(-.5px -.5px 0 rgba(255,255,255,.5))}.piece:hover{z-index:10;filter:drop-shadow(0 1px 0 rgba(0,0,0,.22)) drop-shadow(0 0 .5px rgba(0,0,0,.3)) drop-shadow(3px 8px 14px rgba(0,0,0,.18)) drop-shadow(-.5px -.5px 0 rgba(255,255,255,.4));transform:scale(1.04) translateY(-3px)}.piece.selected{outline:2px solid #6366f1;outline-offset:-2px;z-index:11;filter:drop-shadow(0 1px 0 rgba(0,0,0,.2)) drop-shadow(0 0 .5px rgba(0,0,0,.25)) drop-shadow(0 0 12px rgba(99,102,241,.3)) drop-shadow(2px 6px 10px rgba(0,0,0,.15))}.piece.dragging{cursor:grabbing;z-index:1000!important;filter:drop-shadow(0 2px 0 rgba(0,0,0,.15)) drop-shadow(0 0 1px rgba(0,0,0,.2)) drop-shadow(6px 18px 28px rgba(0,0,0,.22)) drop-shadow(2px 6px 8px rgba(0,0,0,.1));pointer-events:none;transform:scale(1.08) rotate(1deg)}.piece.in-slot{cursor:grab;filter:drop-shadow(0 .5px 0 rgba(0,0,0,.1)) drop-shadow(0 0 .3px rgba(0,0,0,.12)) drop-shadow(-.3px -.3px 0 rgba(255,255,255,.2));animation:piece-snap .3s cubic-bezier(.34,1.56,.64,1)}.piece.piece-locked{cursor:default;pointer-events:none;filter:none}.piece.piece-locked::after{background:0 0}.piece::after{inset:0;background:linear-gradient(145deg,rgba(255,255,255,.18) 0,transparent 35%,transparent 65%,rgba(0,0,0,.08) 100%)}.piece-bank{display:flex;flex-wrap:wrap;gap:8px;align-items:flex-start;align-content:flex-start;padding:20px;background:#fff;border:1.5px solid #d1d5db;border-radius:14px;min-height:140px;transition:border-color .25s,box-shadow .25s;box-shadow:inset 0 2px 6px rgba(0,0,0,.04),0 2px 8px rgba(0,0,0,.06)}.piece-bank:hover{border-color:#9ca3af;box-shadow:inset 0 2px 6px rgba(0,0,0,.04),0 2px 12px rgba(0,0,0,.08)}.bank-placeholder{border:2px dashed rgba(0,0,0,.1);border-radius:4px;opacity:.4;transition:width .3s,height .3s,opacity .3s}.bank-placeholder.collapsing{width:0!important;height:0!important;opacity:0;margin:0;padding:0;overflow:hidden}.puzzle-toolbar{background:#fff;border-bottom:1px solid #e5e7eb;box-shadow:0 1px 3px rgba(0,0,0,.04);max-width:100%}.toolbar-group{display:flex;align-items:center;gap:4px;padding:3px;border-radius:10px;background:#f3f4f6;border:1px solid #e5e7eb;height:36px;box-sizing:border-box}.toolbar-group--stats{gap:0;padding:0;overflow:hidden}.toolbar-group--stats .stat-cell{display:flex;align-items:center;gap:5px;padding:0 12px;height:100%;position:relative}.toolbar-group--stats .stat-cell+.stat-cell::before{content:"";position:absolute;left:0;top:20%;bottom:20%;width:1px;background:#e5e7eb}.stat-cell-icon{color:#9ca3af;flex-shrink:0}.stat-cell-label{font-size:.6rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:#9ca3af;line-height:1;white-space:nowrap}.stat-cell-value{font-size:.82rem;font-weight:800;color:#1f2937;font-variant-numeric:tabular-nums;line-height:1}.toolbar-btn{display:inline-flex;align-items:center;justify-content:center;gap:5px;padding:6px 10px;font-size:.75rem;font-weight:600;border-radius:7px;border:0;background:0 0;color:#6b7280;cursor:pointer;transition:all .15s;white-space:nowrap}.toolbar-btn:hover{background:#e5e7eb;color:#1f2937}.toolbar-btn:active{transform:scale(.97)}.toolbar-btn--active{background:#e0e7ff;color:#4338ca}.btn,.ref-panel img{border:1px solid #e5e7eb}.btn{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;font-size:.78rem;font-weight:600;border-radius:8px;background:#fff;color:#374151;cursor:pointer;height:36px;box-sizing:border-box;transition:all .15s;white-space:nowrap}.btn:hover{background:#f9fafb;border-color:#d1d5db;color:#111827}.btn:active{transform:scale(.97)}.btn-multiplayer,.btn-primary{color:#fff;border-color:transparent}.btn-multiplayer{background:linear-gradient(135deg,#8b5cf6 0,#7c3aed 100%);box-shadow:0 1px 3px rgba(124,58,237,.25)}.btn-multiplayer:hover{background:linear-gradient(135deg,#7c3aed 0,#6d28d9 100%);color:#fff;box-shadow:0 2px 8px rgba(124,58,237,.4);transform:translateY(-1px)}.btn-primary{background:linear-gradient(135deg,#6366f1 0,#4f46e5 100%);box-shadow:0 1px 3px rgba(99,102,241,.25)}.btn-primary:hover{background:linear-gradient(135deg,#4f46e5 0,#4338ca 100%);box-shadow:0 2px 8px rgba(99,102,241,.3)}.toolbar-group--zoom .zoom-label{min-width:36px;text-align:center;font-size:.68rem;font-weight:700;color:#4b5563;font-variant-numeric:tabular-nums;padding:0 1px}.ref-panel{padding:16px 20px;background:#f9fafb;border-bottom:1px solid #e5e7eb;text-align:center}.ref-panel img{max-width:420px;max-height:300px;width:100%;height:auto;border-radius:10px;box-shadow:0 4px 16px rgba(0,0,0,.1)}.win-overlay{display:none;background:rgba(15,23,42,.7);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}.win-overlay.show{display:flex}.win-box{box-shadow:0 24px 80px rgba(0,0,0,.35),0 0 0 1px rgba(255,255,255,.08)}.win-box__stat{background:linear-gradient(135deg,#fefce8 0,#fef9c3 100%);border:1px solid #fde68a}.win-box__stat-value{color:#92400e}.win-box__save-time{background:#f8fafc;border:1px solid #e2e8f0}.win-box__save-time-input{padding:10px 14px;border:1.5px solid #d1d5db;border-radius:10px;font-size:.875rem;outline:0;transition:all .2s}.win-box__save-time-input:focus{border-color:#6366f1;box-shadow:0 0 0 3px rgba(99,102,241,.15)}.win-box__btn--primary,.win-box__save-time-btn{background:#4f46e5;color:#fff;box-shadow:0 1px 3px rgba(79,70,229,.3)}.win-box__save-time-btn{border:0;padding:10px 20px;border-radius:10px;font-weight:600;cursor:pointer;transition:all .2s}.win-box__save-time-btn:hover{background:#4338ca;box-shadow:0 2px 6px rgba(79,70,229,.35)}.win-box__btn--primary{border:1px solid #4f46e5}.win-box__btn--primary:hover{background:#4338ca}.win-box__btn--secondary{background:#fff;color:#4f46e5;border:1.5px solid #c7d2fe}.win-box__btn--secondary:hover{background:#eef2ff;border-color:#a5b4fc}.win-box__suggestions-title{font-size:.8125rem;font-weight:700;color:#6b7280;margin:0 0 10px;text-transform:uppercase;letter-spacing:.05em}.win-box__suggestions-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px;margin-bottom:16px}.win-box__suggestion-card{display:block;text-decoration:none;color:inherit;border:1px solid #e5e7eb;border-radius:12px;overflow:hidden;transition:all .2s}.win-box__suggestion-card:hover{transform:translateY(-2px);box-shadow:0 4px 16px rgba(0,0,0,.1);border-color:#d1d5db}.win-box__invite{font-size:.875rem;color:#6b7280;margin:0 0 16px}.puzzle-card-image{position:relative;overflow:hidden}.puzzle-card-image img{width:100%;display:block;aspect-ratio:4/3;object-fit:cover}.puzzle-card-info{padding:8px 10px}.puzzle-card-title{font-size:.8rem;font-weight:600;margin:0}.puzzle-card-meta{font-size:.7rem;color:#6b7280;margin-top:2px}.puzzle-pieces-badge{background:#eef2ff;color:#4338ca;padding:2px 8px;border-radius:6px;font-size:.7rem;font-weight:700}.puzzle-loading-placeholder{background:rgba(241,240,238,.9);z-index:5;backdrop-filter:blur(4px)}.puzzle-loading-grid{width:56px;height:56px;display:grid;grid-template-columns:repeat(3,1fr);gap:3px;animation:pulse-grid 1.8s ease-in-out infinite}.puzzle-loading-grid::after,.puzzle-loading-grid::before,.puzzle-loading-placeholder-inner::before{content:"";display:block;background:rgba(0,0,0,.12);border-radius:3px}.puzzle-loading-text{font-size:.8rem;color:#6b7280;font-weight:500;letter-spacing:.04em}.puzzle-play-area.puzzle-loaded .puzzle-loading-placeholder{display:none}.puzzle-play-area{max-width:100%}.puzzle-info-bar{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:24px}.puzzle-info-chip{display:inline-flex;align-items:center;gap:7px;padding:7px 14px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;font-size:.8125rem;font-weight:500;color:#475569}.puzzle-info-chip-icon{flex-shrink:0;color:#6366f1}.puzzle-steps{display:flex;flex-direction:column;gap:16px}.puzzle-step{display:flex;align-items:flex-start;gap:14px}.puzzle-step-num{flex-shrink:0;width:30px;height:30px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#4f46e5 0,#6366f1 100%);color:#fff;border-radius:10px;font-size:.8rem;font-weight:800;box-shadow:0 2px 4px rgba(79,70,229,.25)}.puzzle-step-text{margin:0;font-size:.9rem;color:#475569;line-height:1.6;padding-top:4px}.puzzle-tips{display:flex;flex-direction:column;gap:12px}.puzzle-tip{display:flex;align-items:flex-start;gap:12px;padding:10px 14px;background:#fffbeb;border:1px solid #fef3c7;border-radius:10px}.puzzle-tip-icon{flex-shrink:0;color:#d97706;margin-top:1px}.puzzle-tip-text{margin:0;font-size:.875rem;color:#78350f;line-height:1.6}.puzzle-faq-details{border:1px solid #e5e7eb;border-radius:12px;overflow:hidden;transition:border-color .2s}.puzzle-faq-details:hover{border-color:#d1d5db}.puzzle-faq-details[open]{border-color:#c7d2fe;background:#fafbff}.puzzle-faq-summary{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;cursor:pointer;list-style:none}.puzzle-faq-summary::-webkit-details-marker{display:none}.puzzle-faq-chevron{flex-shrink:0;transition:transform .25s;color:#9ca3af}.puzzle-faq-details[open] .puzzle-faq-chevron{transform:rotate(180deg);color:#6366f1}.puzzle-faq-answer{padding:0 18px 16px}.puzzle-game-card.is-fullscreen{position:fixed;inset:0;z-index:9999;overflow:auto;border-radius:0}.puzzle-game-card.is-fullscreen .puzzle-table{min-height:100vh}.section-label-table{color:#9ca3af;letter-spacing:.25em}@media (max-width:768px){.zoom-content{flex-direction:column;align-items:center}.board-section{width:100%;overflow:hidden;text-align:center}.bank-section{width:100%}.board-border{display:block;max-width:100%;box-sizing:border-box}.puzzle-board-container{width:100%!important}.puzzle-header{flex-direction:column;align-items:flex-start}.puzzle-header-actions{margin-left:0;width:100%}.puzzle-toolbar-inner{padding:8px 0;flex-direction:row;flex-wrap:wrap;gap:8px;align-items:center;justify-content:center}.toolbar-group--stats{order:0}.toolbar-group--zoom{order:1}.toolbar-group{height:32px;box-sizing:border-box}.btn-multiplayer span,.stat-cell-label,.toolbar-btn span{display:none}.stat-cell{padding:0 8px;height:100%}.stat-cell-value{font-size:.75rem}.toolbar-btn{padding:0 7px;min-width:30px;height:100%}.btn{height:32px;box-sizing:border-box;font-size:.72rem}.btn-multiplayer{justify-content:center}.section-label-table{font-size:9px;letter-spacing:.15em;margin-bottom:6px}}@media (max-width:640px){.puzzle-play-area{padding:10px;overflow-x:hidden;min-height:50vh}.zoom-content{gap:12px}.piece-bank{padding:10px;min-height:80px;gap:4px;border-radius:10px;border-width:1px}.board-border{border-width:4px;border-radius:6px}.puzzle-toolbar{padding:4px 10px}.ref-panel{padding:10px 16px}.ref-panel img{max-height:180px;border-radius:8px}}@media (max-width:400px){.puzzle-toolbar{padding:4px 8px}.toolbar-group--zoom{gap:1px;padding:2px}.toolbar-group{height:30px}.toolbar-btn{padding:0 5px;min-width:26px}.zoom-label{min-width:28px!important;font-size:.6rem!important}.puzzle-play-area{padding:6px}.board-border{border-width:3px;border-radius:4px}.piece-bank{padding:8px;gap:3px;border-radius:8px}}.mp-hero{background:linear-gradient(135deg,#312e81 0,#4338ca 50%,#6366f1 100%);color:#fff;padding:0;position:relative}.mp-hero__inner{padding:32px 28px 24px;text-align:center}.mp-hero__title{margin:0 0 6px;font-size:1.5rem;font-weight:800;color:#fff;line-height:1.25}.mp-hero__tagline{margin:0 0 16px;font-size:.875rem;color:rgba(255,255,255,.75);font-weight:400}.mp-hero__chips{display:flex;flex-wrap:wrap;gap:8px;justify-content:center}.mp-hero__chip{display:inline-flex;align-items:center;gap:5px;padding:5px 12px;font-size:.75rem;font-weight:600;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.15);border-radius:20px;color:rgba(255,255,255,.9)}.mp-hero__actions{background:rgba(0,0,0,.15);padding:10px 28px;border-top:1px solid rgba(255,255,255,.08)}.mp-hero__actions-meta{display:flex;align-items:center;gap:12px;justify-content:center;min-height:24px}.puzzle-mp-badge{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;font-size:.7rem;font-weight:700;background:rgba(255,255,255,.15);border-radius:12px;color:#fff}.puzzle-mp-badge:empty,.puzzle-mp-ws-status:empty{display:none}.puzzle-mp-ws-status{font-size:.7rem;font-weight:600;padding:3px 10px;border-radius:12px;transition:all .3s}.puzzle-mp-ws-status.ws-connected{background:rgba(34,197,94,.2);color:#86efac}.puzzle-mp-ws-status.ws-connected::before{content:"";display:inline-block;width:6px;height:6px;border-radius:50%;background:#4ade80;margin-right:5px;vertical-align:middle;box-shadow:0 0 4px #4ade80;animation:ws-pulse 2s ease-in-out infinite}.puzzle-mp-ws-status.ws-connecting{background:rgba(250,204,21,.2);color:#fde68a}.puzzle-mp-ws-status.ws-offline{background:rgba(239,68,68,.15);color:#fca5a5}.mp-player-toast{position:absolute;bottom:8px;left:50%;transform:translateX(-50%) translateY(8px);padding:6px 16px;font-size:.75rem;font-weight:600;background:rgba(0,0,0,.7);color:#fff;border-radius:20px;opacity:0;pointer-events:none;transition:opacity .3s,transform .3s;white-space:nowrap;z-index:10}.mp-player-toast.show{opacity:1;transform:translateX(-50%) translateY(0)}.mp-lobby{padding:32px 24px;background:#f9fafb;border-top:1px solid #e5e7eb}.mp-lobby__inner{display:flex;gap:32px;max-width:720px;margin:0 auto;align-items:flex-start}.mp-lobby__preview{flex-shrink:0;width:240px}.mp-lobby__image{width:100%;border-radius:12px;box-shadow:0 4px 16px rgba(0,0,0,.1);border:1px solid #e5e7eb}.mp-lobby__options{flex:1;min-width:0}.mp-lobby__title{margin:0 0 4px;font-size:1.15rem;font-weight:700;color:#1f2937}.mp-lobby__subtitle{margin:0 0 20px;font-size:.85rem;color:#6b7280}.mp-lobby__buttons{display:flex;gap:10px;margin-bottom:20px}.mp-lobby__btn{flex:1;justify-content:center;padding:10px 16px;font-size:.82rem}.mp-lobby__btn--primary{background:linear-gradient(135deg,#6366f1 0,#4f46e5 100%);color:#fff;border-color:transparent;box-shadow:0 1px 3px rgba(99,102,241,.25)}.mp-lobby__btn--primary:hover{background:linear-gradient(135deg,#4f46e5 0,#4338ca 100%);box-shadow:0 2px 8px rgba(99,102,241,.3)}.mp-lobby__btn--secondary{background:#fff;color:#374151;border:1px solid #d1d5db}.mp-lobby__btn--secondary:hover{background:#f3f4f6;border-color:#9ca3af}.mp-lobby__divider{position:relative;text-align:center;margin-bottom:16px}.mp-lobby__divider::before{content:"";position:absolute;top:50%;left:0;right:0;height:1px;background:#e5e7eb}.mp-lobby__divider span{position:relative;padding:0 12px;font-size:.75rem;color:#9ca3af;background:#f9fafb;font-weight:500}.mp-lobby__join-row{display:flex;gap:8px}.mp-lobby__join-input{flex:1;padding:9px 14px;font-size:.82rem;border:1.5px solid #d1d5db;border-radius:8px;outline:0;transition:border-color .2s,box-shadow .2s}.mp-lobby__join-input:focus{border-color:#6366f1;box-shadow:0 0 0 3px rgba(99,102,241,.12)}.mp-lobby__join-btn{padding:9px 18px;font-size:.82rem}.mp-lobby__error{margin:10px 0 0;font-size:.78rem;color:#dc2626;font-weight:500}.mp-invite-banner{display:flex;flex-wrap:wrap;align-items:center;gap:10px;padding:12px 20px;background:#eef2ff;border-bottom:1px solid #c7d2fe}.mp-contributors.hidden,.mp-invite-banner.hidden,.mp-invite-banner__copied.hidden,.mp-progress.hidden{display:none}.mp-invite-banner__text{font-size:.8rem;font-weight:600;color:#4338ca}.mp-invite-banner__url{flex:1;min-width:160px;padding:6px 10px;font-size:.75rem;border:1px solid #c7d2fe;border-radius:6px;background:#fff;color:#4338ca;outline:0}.mp-invite-banner__copied{font-size:.75rem;font-weight:600;color:#16a34a}.mp-invite-banner__actions{display:flex;gap:6px}.mp-progress{display:flex;align-items:center;gap:12px;padding:10px 20px;background:#fff;border-bottom:1px solid #e5e7eb}.mp-progress__bar{flex:1;height:8px;background:#e5e7eb;border-radius:4px;overflow:hidden}.mp-progress__fill{height:100%;background:linear-gradient(90deg,#6366f1,#8b5cf6);border-radius:4px;transition:width .4s ease;width:0}.mp-progress__count{font-size:.75rem;font-weight:700;color:#6b7280;white-space:nowrap;font-variant-numeric:tabular-nums}.mp-contributors{padding:16px 20px;background:#f9fafb;border-top:1px solid #e5e7eb}.mp-contributors__title{margin:0 0 10px;font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:#6b7280}.mp-contributors__list{list-style:none;margin:0;padding:0;display:flex;flex-wrap:wrap;gap:8px}.mp-contributors__item{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;background:#fff;border:1px solid #e5e7eb;border-radius:20px;font-size:.78rem}.mp-contributors__name{font-weight:600;color:#1e1b4b}.mp-contributors__count{font-weight:700;color:#6366f1;font-size:.75rem}.mp-scoreboard{margin-top:12px;padding:16px 20px;background:#fff;border:1px solid #e5e7eb;border-radius:16px}.mp-scoreboard__title{font-size:.95rem;font-weight:700;color:#1e1b4b;margin:0 0 12px}.mp-scoreboard__table-wrap{overflow-x:auto}.mp-scoreboard__table{width:100%;border-collapse:collapse;font-size:.85rem}.mp-scoreboard__th{text-align:left;font-weight:600;color:#6b7280;font-size:.7rem;text-transform:uppercase;letter-spacing:.04em;padding:0 8px 8px;border-bottom:1px solid #f3f4f6}.mp-scoreboard__th--rank{width:36px;text-align:center}.mp-scoreboard__th--pieces{text-align:right}.mp-scoreboard__td{padding:8px;border-bottom:1px solid #f9fafb;color:#374151}.mp-scoreboard__td--rank{text-align:center;font-weight:700;color:#a5b4fc}.mp-scoreboard__td--pieces{text-align:right;font-weight:700;color:#4f46e5}.mp-scoreboard__row--me{background:rgba(99,102,241,.05)}.mp-scoreboard__row--me .mp-scoreboard__td--name{font-weight:600}.mp-scoreboard__you{font-size:.7rem;color:#818cf8;font-weight:500}.mp-scoreboard__row:first-child .mp-scoreboard__td--rank{color:#f59e0b}.mp-scoreboard__empty{color:#9ca3af;font-size:.8rem;text-align:center;margin:8px 0 0}.mp-win-scoreboard{text-align:left;margin:0 -4px;max-height:200px;overflow-y:auto}.mp-win-scoreboard .mp-scoreboard__table{font-size:.82rem}.mp-win-scoreboard .mp-scoreboard__td--rank{font-size:.85rem}.mp-next{margin-top:16px;padding:24px;background:linear-gradient(135deg,#f5f3ff 0,#eef2ff 50%,#f0fdf4 100%);border:1px solid #e0e7ff;border-radius:20px;position:relative;overflow:hidden}.mp-next::before{content:"";position:absolute;top:-40px;right:-40px;width:120px;height:120px;background:radial-gradient(circle,rgba(99,102,241,.08) 0,transparent 70%);pointer-events:none}.mp-next.hidden{display:none}.mp-next__header{display:flex;align-items:center;gap:14px;margin-bottom:20px}.mp-next__icon{display:flex;align-items:center;justify-content:center;width:44px;height:44px;flex-shrink:0;border-radius:14px;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;box-shadow:0 2px 8px rgba(99,102,241,.3)}.mp-next__title{margin:0;font-size:1.05rem;font-weight:800;color:#1e1b4b;line-height:1.2}.mp-next__subtitle{margin:2px 0 0;font-size:.78rem;color:#6b7280;font-weight:400}.mp-next__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.mp-next__card{display:flex;flex-direction:column;border-radius:14px;overflow:hidden;border:2px solid #e5e7eb;text-decoration:none;transition:border-color .2s,box-shadow .2s,transform .2s;background:#fff}.mp-next__card:hover{border-color:#818cf8;box-shadow:0 4px 16px rgba(99,102,241,.2);transform:translateY(-3px)}.mp-next__card-img-wrap{position:relative;overflow:hidden}.mp-next__card-img{width:100%;aspect-ratio:1;object-fit:cover;transition:transform .3s}.mp-next__card:hover .mp-next__card-img{transform:scale(1.05)}.mp-next__card-badge{position:absolute;top:6px;right:6px;padding:2px 8px;font-size:.6rem;font-weight:700;border-radius:6px;letter-spacing:.02em;text-transform:uppercase;line-height:1.5}.mp-next__card-body{padding:8px 10px 10px;display:flex;flex-direction:column;gap:2px}.mp-next__card-name{font-size:.75rem;font-weight:700;color:#1e1b4b;line-height:1.25;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mp-next__card-meta{display:inline-flex;align-items:center;gap:4px;font-size:.65rem;color:#9ca3af;font-weight:500}.mp-next__footer{margin-top:16px;text-align:center}.mp-next__browse{display:inline-flex;align-items:center;gap:6px;font-size:.82rem;color:#6366f1;text-decoration:none;font-weight:700;transition:gap .2s}.mp-next__browse:hover{text-decoration:underline;gap:10px}.mp-suggestion{margin-top:12px;padding:14px 18px;background:#fff;border:2px solid #c7d2fe;border-radius:16px;display:flex;align-items:center;gap:14px;animation:mp-suggestion-in .4s ease}.mp-suggestion.hidden{display:none}.mp-suggestion__img{width:56px;height:56px;border-radius:10px;object-fit:cover;flex-shrink:0;border:1px solid #e5e7eb}.mp-suggestion__body{flex:1;min-width:0}.mp-suggestion__text{font-size:.8rem;color:#374151;margin:0 0 2px;line-height:1.35}.mp-suggestion__text strong{font-weight:700;color:#4338ca}.mp-suggestion__puzzle-name{font-size:.85rem;font-weight:700;color:#1e1b4b}.mp-suggestion__join{flex-shrink:0;padding:8px 16px;font-size:.78rem;font-weight:700;color:#fff;background:linear-gradient(135deg,#6366f1,#4f46e5);border:0;border-radius:10px;cursor:pointer;text-decoration:none;transition:box-shadow .2s,transform .2s;display:inline-flex;align-items:center;gap:6px}.mp-suggestion__join:hover{box-shadow:0 3px 12px rgba(99,102,241,.35);transform:translateY(-1px)}.mp-name-modal{position:fixed;inset:0;z-index:10000;display:flex;align-items:center;justify-content:center;animation:mp-name-modal-in .3s ease}.mp-name-modal.hidden{display:none}.mp-name-modal__backdrop{position:absolute;inset:0;background:rgba(0,0,0,.5);backdrop-filter:blur(4px)}.mp-name-modal__card{position:relative;background:#fff;border-radius:20px;padding:32px 28px;width:340px;max-width:90vw;text-align:center;box-shadow:0 20px 60px rgba(0,0,0,.2)}.mp-name-modal__icon{display:inline-flex;align-items:center;justify-content:center;width:56px;height:56px;border-radius:16px;background:linear-gradient(135deg,#eef2ff,#e0e7ff);color:#4f46e5;margin-bottom:16px}.mp-name-modal__title{margin:0 0 4px;font-size:1.15rem;font-weight:800;color:#1e1b4b}.mp-name-modal__subtitle{margin:0 0 20px;font-size:.82rem;color:#6b7280}.mp-name-modal__input{width:100%;padding:12px 16px;font-size:.95rem;border:2px solid #e5e7eb;border-radius:12px;outline:0;transition:border-color .2s,box-shadow .2s;text-align:center;font-weight:600}.mp-name-modal__input:focus{border-color:#6366f1;box-shadow:0 0 0 4px rgba(99,102,241,.12)}.mp-name-modal__btn{margin-top:14px;width:100%;padding:12px;font-size:.92rem;font-weight:700;color:#fff;background:linear-gradient(135deg,#6366f1,#4f46e5);border:0;border-radius:12px;cursor:pointer;transition:box-shadow .2s,transform .2s}.mp-name-modal__btn:hover{box-shadow:0 4px 16px rgba(99,102,241,.35);transform:translateY(-1px)}.mp-name-modal__btn:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none}.mp-cursor,.mp-cursors{position:fixed;pointer-events:none}.mp-cursors{inset:0;z-index:9998}.mp-cursor{padding:2px 8px;font-size:.65rem;font-weight:600;color:#fff;background:rgba(99,102,241,.85);border-radius:0 8px 8px 8px;white-space:nowrap;transform:translate(4px,4px);transition:left .08s linear,top .08s linear;box-shadow:0 1px 4px rgba(0,0,0,.18)}.mp-cursor::before{content:"";position:absolute;top:-4px;left:-4px;width:10px;height:10px;border-radius:50%;background:#818cf8;border:2px solid #fff;box-shadow:0 0 4px rgba(99,102,241,.5)}@media (max-width:640px){.puzzle-page-content--multiplayer{overflow-x:hidden}.puzzle-game-card--multiplayer{padding:0!important;margin-bottom:0!important}.puzzle-wrap--multiplayer{border-radius:0;border-left:none;border-right:none;overflow-x:hidden}.mp-hero{border-radius:0}.mp-hero__inner{padding:16px 16px 12px}.mp-hero__title{font-size:1.05rem;margin-bottom:4px}.mp-hero__tagline{font-size:.75rem;margin-bottom:8px}.mp-hero__chips{gap:5px}.mp-hero__chip{padding:3px 8px;font-size:.65rem;gap:4px}.mp-hero__chip svg{width:11px;height:11px}.mp-hero__actions{padding:6px 16px}.mp-hero__actions-meta{gap:8px;min-height:20px}.puzzle-mp-badge,.puzzle-mp-ws-status{font-size:.65rem;padding:2px 8px}.mp-lobby{padding:20px 16px}.mp-lobby__inner{flex-direction:column;align-items:stretch;gap:16px}.mp-lobby__preview{width:100%;max-width:240px;margin:0 auto}.mp-lobby__image{border-radius:10px}.mp-lobby__options{text-align:center}.mp-lobby__title{font-size:1rem}.mp-lobby__subtitle{font-size:.8rem;margin-bottom:16px}.mp-lobby__buttons{flex-direction:column;gap:8px;margin-bottom:16px;max-width:260px;margin-left:auto;margin-right:auto}.mp-lobby__btn{padding:11px 16px;font-size:.85rem}.mp-lobby__divider{margin-bottom:12px}.mp-lobby__join-row{flex-direction:column;gap:8px;max-width:260px;margin-left:auto;margin-right:auto}.mp-lobby__join-input{text-align:center}.mp-invite-banner #mp-copy-link,.mp-lobby__join-btn{width:100%;justify-content:center}.mp-invite-banner{flex-direction:column;align-items:stretch;gap:6px;padding:10px 16px}.mp-invite-banner__text{font-size:.72rem;text-align:center}.mp-invite-banner__url{min-width:0;width:100%;font-size:.68rem;padding:7px 10px;text-align:center}.mp-invite-banner #mp-copy-link{font-size:.78rem}.mp-invite-banner__copied{text-align:center}.mp-progress{padding:6px 16px;gap:10px}.mp-progress__bar{height:6px}.mp-progress__count{font-size:.68rem}.mp-contributors{padding:10px 16px}.mp-contributors__title{font-size:.68rem;margin-bottom:6px}.mp-contributors__list{gap:6px}.mp-contributors__item{padding:3px 8px;font-size:.7rem;gap:4px}.mp-scoreboard{padding:12px 16px;margin-top:0;border-radius:0;border-left:none;border-right:none}.mp-scoreboard__title{font-size:.85rem;margin-bottom:8px}.mp-scoreboard__table{font-size:.78rem}.mp-scoreboard__th{font-size:.62rem;padding:0 6px 6px}.mp-scoreboard__td{padding:6px}.mp-next{padding:16px;margin-top:0;border-radius:0;border-left:none;border-right:none}.mp-next__header{gap:10px;margin-bottom:12px}.mp-next__grid{grid-template-columns:repeat(3,1fr);gap:6px}.mp-next__icon{width:32px;height:32px;border-radius:9px}.mp-next__icon svg{width:16px;height:16px}.mp-next__title{font-size:.85rem}.mp-next__subtitle{font-size:.7rem}.mp-next__card{border-radius:8px;border-width:1.5px}.mp-next__card-img{aspect-ratio:4/3}.mp-next__card-badge{top:4px;right:4px;padding:1px 5px;font-size:.5rem}.mp-next__card-body{padding:5px 6px 6px}.mp-next__card-name{font-size:.65rem}.mp-next__card-meta{font-size:.58rem}.mp-next__footer{margin-top:10px}.mp-next__browse{font-size:.78rem}.mp-suggestion{flex-wrap:wrap;gap:10px;padding:12px 16px;border-radius:0;border-left:none;border-right:none;margin-top:0}.mp-suggestion__img{width:42px;height:42px;border-radius:8px}.mp-suggestion__text{font-size:.75rem}.mp-suggestion__puzzle-name{font-size:.8rem}.mp-suggestion__join{width:100%;justify-content:center;padding:10px 16px;border-radius:8px}.mp-name-modal__card{padding:24px 20px;width:300px;border-radius:16px}.mp-name-modal__icon{width:48px;height:48px;border-radius:14px;margin-bottom:12px}.mp-name-modal__title{font-size:1.05rem}.mp-name-modal__subtitle{font-size:.78rem;margin-bottom:16px}.mp-name-modal__input{padding:10px 14px;font-size:.9rem;border-radius:10px}.mp-name-modal__btn{padding:11px;font-size:.88rem;border-radius:10px;margin-top:12px}}@media (max-width:380px){.mp-hero__inner{padding:14px 12px 10px}.mp-hero__title{font-size:.95rem}.mp-hero__tagline{display:none}.mp-hero__chip{padding:2px 6px;font-size:.6rem}.mp-lobby{padding:16px 12px}.mp-lobby__preview{max-width:200px}.mp-next__grid{grid-template-columns:repeat(2,1fr)}.mp-invite-banner{padding:8px 12px}}.community-hero-section+.puzzle-page-content{padding-top:20px;padding-bottom:0}.community-hero-section+.puzzle-page-content .puzzle-game-card{border-radius:16px;overflow:hidden;box-shadow:0 4px 24px rgba(0,0,0,.08),0 1px 3px rgba(0,0,0,.04);border:1px solid #e5e7eb;background:#fff}.community-hero-section{position:relative;overflow:hidden;padding:0}.community-hero-bg{position:absolute;inset:0;background:linear-gradient(135deg,#1e1b4b 0,#312e81 25%,#4c1d95 50%,#581c87 75%,#1e1b4b 100%)}.community-hero-glow{position:absolute;width:500px;height:500px;top:50%;left:50%;border-radius:50%;background:radial-gradient(circle,rgba(139,92,246,.35) 0,transparent 70%);animation:community-glow-shift 8s ease-in-out infinite;pointer-events:none}.community-hero-content{position:relative;padding-top:14px;padding-bottom:0}.community-hero-breadcrumb{display:flex;align-items:center;gap:6px;font-size:.75rem;margin-bottom:14px}.community-hero-breadcrumb a{color:rgba(255,255,255,.45);text-decoration:none;transition:color .15s}.community-hero-breadcrumb a:hover{color:rgba(255,255,255,.85)}.community-hero-breadcrumb svg{color:rgba(255,255,255,.25)}.community-hero-breadcrumb span{color:rgba(255,255,255,.7);font-weight:600}.community-hero-main{display:flex;align-items:center;justify-content:space-between;gap:24px;margin-bottom:20px}.community-hero-text{flex:1;min-width:0}.community-hero-live-tag{display:inline-flex;align-items:center;gap:6px;font-size:.6rem;font-weight:800;letter-spacing:.12em;color:#a5f3fc;background:rgba(6,182,212,.15);border:1px solid rgba(6,182,212,.25);padding:3px 10px;border-radius:20px;margin-bottom:10px}.community-live-dot{width:6px;height:6px;border-radius:50%;background:#22d3ee;animation:community-pulse 2s ease-in-out infinite}.community-hero-title{font-size:1.5rem;font-weight:800;color:#fff;margin:0 0 6px;line-height:1.2;letter-spacing:-.02em}.community-hero-subtitle{font-size:.8rem;color:rgba(255,255,255,.5);margin:0;line-height:1.5}.community-hero-stats{display:flex;align-items:center;gap:16px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.08);border-radius:16px;padding:14px 22px;backdrop-filter:blur(12px);flex-shrink:0}.community-hero-stat{display:flex;flex-direction:column;align-items:center;gap:2px}.community-hero-stat-value{font-size:1.25rem;font-weight:800;color:#fff;font-variant-numeric:tabular-nums;line-height:1}.community-hero-stat-label{font-size:.6rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:rgba(255,255,255,.4)}.community-hero-stat-divider{width:1px;height:28px;background:rgba(255,255,255,.1)}.community-hero-bar{background:rgba(0,0,0,.2);border-top:1px solid rgba(255,255,255,.06)}.community-hero-bar-inner{display:flex;align-items:center;justify-content:space-between;gap:16px;padding-top:8px;padding-bottom:8px}.community-hero-bar-left,.community-hero-bar-progress{display:flex;align-items:center;gap:10px}.community-hero-bar-progress{flex:1;max-width:280px}.community-hero-bar-track{flex:1;height:5px;background:rgba(255,255,255,.1);border-radius:3px;overflow:hidden}.community-hero-bar-fill{height:100%;border-radius:3px;background:linear-gradient(90deg,#818cf8,#c084fc,#818cf8);background-size:200% 100%;animation:community-bar-shimmer 3s linear infinite;transition:width .5s ease}.community-hero-bar-pct{font-size:.65rem;font-weight:700;color:rgba(255,255,255,.6);font-variant-numeric:tabular-nums;min-width:32px;text-align:right}.community-ws-badge{display:inline-flex;align-items:center;gap:6px;font-size:.65rem;font-weight:600;padding:4px 10px;border-radius:6px;background:rgba(255,255,255,.06);color:rgba(255,255,255,.5);border:1px solid rgba(255,255,255,.06);transition:all .3s ease}.community-ws-badge-dot{width:6px;height:6px;border-radius:50%;background:rgba(255,255,255,.3);transition:all .3s ease}.community-ws-badge--connected{background:rgba(16,185,129,.12);border-color:rgba(16,185,129,.2);color:#6ee7b7}.community-ws-badge--connected .community-ws-badge-dot{background:#34d399;animation:community-pulse 2s ease-in-out infinite}.community-ws-badge--offline{background:rgba(239,68,68,.1);border-color:rgba(239,68,68,.15);color:#fca5a5}.community-ws-badge--offline .community-ws-badge-dot{background:#f87171}.community-players-badge{font-size:.65rem;font-weight:600;padding:4px 10px;border-radius:6px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.06);color:rgba(255,255,255,.6)}.community-live-panel{background:#fff;border-top:2px solid #f3f4f6}.community-live-panel-row{padding:16px 24px}.community-live-panel-row+.community-live-panel-row{border-top:1px solid #f3f4f6}.community-progress__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.community-progress__label{display:flex;align-items:center;gap:6px;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:#6b7280}.community-contributions__header svg,.community-progress__label svg{color:#a5b4fc}.community-progress__count{font-size:.75rem;font-weight:700;color:#4f46e5;font-variant-numeric:tabular-nums}.community-progress__bar{height:8px;background:#f3f4f6;border-radius:4px;overflow:hidden}.community-progress__fill{height:100%;background:linear-gradient(90deg,#818cf8,#a78bfa,#c084fc);background-size:200% 100%;border-radius:4px;transition:width .4s ease;animation:community-bar-shimmer 4s linear infinite}.community-contributions__header{display:flex;align-items:center;gap:8px;margin-bottom:10px}.community-contributions__title{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:#6b7280;margin:0}.community-contributions__list{display:flex;flex-direction:column;gap:4px;max-height:200px;overflow-y:auto}.community-completed-overlay{display:none;position:fixed;inset:0;z-index:1000;background:rgba(15,23,42,.7);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);align-items:center;justify-content:center;padding:24px}.community-completed-overlay.show,.community-history-modal.show{display:flex}.community-completed-box{background:#fff;border-radius:24px;padding:32px;max-width:480px;width:100%;text-align:center;box-shadow:0 24px 80px rgba(0,0,0,.35)}.community-completed-box__icon{font-size:3rem;margin-bottom:12px}.community-completed-box__title{font-size:1.5rem;font-weight:800;color:#111827;margin:0 0 8px}.community-completed-box__subtitle{font-size:.875rem;color:#6b7280;margin:0 0 16px;line-height:1.5}.community-completed-box__countdown{margin-bottom:16px}.community-completed-box__countdown-hero{display:flex;align-items:baseline;justify-content:center;gap:4px}.community-completed-box__countdown-num{font-size:2.5rem;font-weight:800;color:#4f46e5;font-variant-numeric:tabular-nums}.community-completed-box__countdown-unit{font-size:1rem;font-weight:600;color:#9ca3af}.community-completed-box__stats{display:flex;justify-content:center;gap:12px;margin-bottom:16px}.community-completed-box__contributors{max-height:180px;overflow-y:auto;text-align:left}.community-history-section{max-width:56rem;margin:48px auto;padding:0 16px}.community-history-modal{display:none;position:fixed;inset:0;z-index:1100;align-items:center;justify-content:center}.community-history-modal__backdrop{position:absolute;inset:0;background:rgba(15,23,42,.5);backdrop-filter:blur(6px)}.community-history-modal__panel{position:relative;background:#fff;border-radius:20px;padding:28px;max-width:480px;width:calc(100% - 32px);max-height:80vh;overflow-y:auto;box-shadow:0 24px 60px rgba(0,0,0,.25)}.community-history-modal__close{position:absolute;top:12px;right:12px;width:32px;height:32px;border:0;background:0 0;font-size:1.25rem;color:#9ca3af;cursor:pointer;border-radius:8px;display:flex;align-items:center;justify-content:center}.community-history-modal__close:hover{background:#f3f4f6;color:#374151}.community-history-modal__title{font-size:1.1rem;font-weight:700;color:#111827;margin:0 0 12px}.community-history-modal__puzzle-wrap{margin-bottom:12px;text-align:center}.community-history-modal__puzzle-img{max-width:200px;max-height:140px;border-radius:10px;border:1px solid #e5e7eb}.community-history-modal__contributors{max-height:200px;overflow-y:auto}.community-cursors{position:absolute;inset:0;pointer-events:none;z-index:50}.community-cursor{position:absolute;transition:left .1s linear,top .1s linear}.community-cursor__pointer{width:12px;height:12px;background:#8b5cf6;border:2px solid #fff;border-radius:50%;box-shadow:0 1px 4px rgba(0,0,0,.2)}.community-cursor__label{position:absolute;top:-18px;left:14px;font-size:.6rem;font-weight:600;color:#7c3aed;background:rgba(255,255,255,.9);padding:1px 5px;border-radius:4px;white-space:nowrap;box-shadow:0 1px 3px rgba(0,0,0,.1)}@media (max-width:768px){.community-hero-content{padding:12px 16px 0}.community-hero-title{font-size:1.15rem}.community-hero-main{flex-direction:column;gap:12px;align-items:flex-start}.community-hero-stats{align-self:stretch;justify-content:center;padding:10px 16px;gap:12px}.community-hero-stat-value{font-size:1rem}.community-hero-bar-inner{flex-wrap:wrap}.community-hero-bar-progress{max-width:none}.community-hero-section+.puzzle-page-content .puzzle-game-card{border-radius:12px}.community-completed-box{padding:24px 20px}.community-live-panel-row{padding:12px 16px}}.contact-input{width:100%;padding:10px 14px;border:1px solid #e5e7eb;border-radius:.75rem;font-size:.925rem;color:#111827;background:#fff;outline:0;transition:border-color .15s ease,box-shadow .15s ease}.contact-input:focus{border-color:#6366f1;box-shadow:0 0 0 3px rgba(99,102,241,.12)}.contact-textarea{resize:vertical;min-height:120px}.contact-char-count{text-align:right;font-size:.75rem;color:#9ca3af;margin-top:4px}.contact-char-count--warn{color:#f59e0b}.contact-char-count--limit{color:#ef4444;font-weight:600}.contact-honeypot{position:absolute;left:-9999px;height:0;overflow:hidden;opacity:0;pointer-events:none}.contact-submit-btn{display:inline-flex;align-items:center;gap:8px;padding:11px 28px;background:#4f46e5;color:#fff;font-weight:600;font-size:.925rem;border:0;border-radius:.75rem;cursor:pointer;transition:background .15s ease,box-shadow .15s ease}.contact-submit-btn:hover{background:#4338ca;box-shadow:0 4px 12px rgba(79,70,229,.3)}.contact-submit-btn:active{background:#3730a3}.contact-submit-btn:disabled{opacity:.5;cursor:not-allowed;box-shadow:none}.contact-form-message{display:none;padding:12px 16px;border-radius:.75rem;font-size:.875rem;font-weight:500;margin-bottom:20px}.contact-form-message--success{display:flex;align-items:center;gap:10px;background:#ecfdf5;color:#065f46;border:1px solid #a7f3d0}.contact-form-message--error{display:flex;align-items:center;gap:10px;background:#fef2f2;color:#991b1b;border:1px solid #fecaca}.header-main{background:rgba(255,255,255,.92);backdrop-filter:blur(24px) saturate(1.6);-webkit-backdrop-filter:blur(24px) saturate(1.6);border-bottom:1px solid rgba(0,0,0,.06);box-shadow:0 1px 2px rgba(0,0,0,.03);position:sticky;top:0;z-index:50}.header-glow{position:absolute;bottom:-1px;left:50%;transform:translateX(-50%);width:40%;height:1px;background:linear-gradient(90deg,transparent,rgba(99,102,241,.2),transparent);pointer-events:none}.header-logo{display:flex;align-items:center;text-decoration:none;transition:transform .2s ease}.header-logo:hover{transform:translateY(-.5px)}.header-logo-text{font-family:"Inter",system-ui,sans-serif;font-size:1.25rem;font-weight:800;letter-spacing:-.04em;color:#1e1b4b;line-height:1}.header-logo-o{position:relative;display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;margin-left:1px;vertical-align:middle}.header-logo-o svg{position:absolute;inset:0;width:100%;height:100%;filter:drop-shadow(0 1px 3px rgba(99,102,241,.35));transition:filter .25s ease,transform .25s ease}.group:hover .header-logo-o svg{filter:drop-shadow(0 2px 8px rgba(99,102,241,.5));transform:rotate(8deg) scale(1.06)}.header-logo-o-letter{position:relative;z-index:1;font-family:"Inter",system-ui,sans-serif;font-size:.8rem;font-weight:900;color:#fff;line-height:1;text-shadow:0 1px 2px rgba(0,0,0,.15)}.header-logo-img{display:block;height:38px;width:auto;max-width:min(300px,58vw);object-fit:contain;object-position:left center;transition:opacity .2s ease,transform .2s ease}.group:hover .header-logo-img{opacity:.9;transform:translateY(-.5px)}.header-nav-link{display:inline-flex;align-items:center;gap:5px;padding:6px 12px;border-radius:8px;font-size:.8125rem;font-weight:500;color:#6b7280;transition:color .15s ease,background .15s ease;letter-spacing:-.01em}.header-nav-link:hover{color:#111827;background:rgba(0,0,0,.04)}.header-nav-link--daily{color:#4f46e5;font-weight:600}.header-nav-link--daily:hover{color:#4338ca;background:rgba(99,102,241,.08)}.header-nav-link__icon{width:15px;height:15px;flex-shrink:0;opacity:.7}.header-nav-primary{display:flex;align-items:center;justify-content:center;flex-wrap:nowrap;gap:2px;min-width:0;flex:1}.header-nav-utilities{display:flex;align-items:center;flex-shrink:0;gap:6px}.header-lang-btn{display:inline-flex;align-items:center;gap:5px;padding:5px 8px;border-radius:8px;color:#6b7280;transition:color .15s ease,background .15s ease;cursor:pointer}.header-lang-btn:hover{color:#111827}.header-flag,.header-flag-sm{width:18px;height:18px;border-radius:50%;object-fit:cover;box-shadow:0 0 0 1.5px rgba(0,0,0,.08)}.header-flag-sm{width:20px;height:20px;box-shadow:0 0 0 1px rgba(0,0,0,.06)}.header-lang-code{font-size:.6875rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase}.header-lang-chevron{width:.75rem;height:.75rem;opacity:.35;flex-shrink:0}.header-dropdown{background:rgba(255,255,255,.98);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-radius:12px;box-shadow:0 8px 30px rgba(0,0,0,.08),0 0 0 1px rgba(0,0,0,.05);z-index:50;overflow:hidden}.header-dropdown-item{width:100%;display:flex;align-items:center;gap:10px;padding:8px 12px;border-radius:8px;font-size:.8125rem;color:#374151;transition:background .12s ease;cursor:pointer}.header-dropdown-item:hover,.header-lang-btn:hover{background:rgba(0,0,0,.04)}.header-dropdown-item--active{font-weight:600;color:#4f46e5;background:rgba(99,102,241,.06)}.header-user-capsule{display:inline-flex;align-items:center;gap:7px;padding:4px 6px 4px 4px;border-radius:10px;background:rgba(0,0,0,.025);border:1px solid rgba(0,0,0,.06);transition:background .15s ease,border-color .15s ease,box-shadow .15s ease;text-decoration:none}.header-user-capsule:hover{background:rgba(0,0,0,.05);border-color:rgba(0,0,0,.1);box-shadow:0 1px 4px rgba(0,0,0,.06)}.header-user-avatar{width:28px;height:28px;border-radius:8px;background:linear-gradient(135deg,#eef2ff,#e0e7ff);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:#6366f1}.header-user-name{max-width:100px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:.8125rem;font-weight:600;color:#374151;letter-spacing:-.01em}.header-points-badge{display:inline-flex;align-items:center;gap:3px;padding:2px 8px;border-radius:6px;background:linear-gradient(135deg,#fef9c3,#fde68a);color:#92400e;font-size:.6875rem;font-weight:700;letter-spacing:.01em}@media (min-width:768px){.header-nav-primary{gap:4px}.header-nav-utilities{gap:8px}.header-nav-link{padding:7px 12px;font-size:.875rem;font-weight:600;color:#4b5563}.header-nav-link:hover{color:#111827}.header-nav-link--daily{color:#4f46e5}.header-nav-link--daily:hover{color:#4338ca}.header-nav-link__icon{width:16px;height:16px}.header-lang-btn{padding:6px 11px;gap:6px;border-radius:9px}.header-lang-chevron{opacity:.4}.header-flag{width:19px;height:19px}.header-lang-code{font-size:.75rem}.header-user-capsule{gap:8px;padding:5px 8px 5px 5px;border-radius:11px}.header-user-avatar{width:30px;height:30px}.header-user-name{max-width:112px;font-size:.875rem}.header-points-badge{padding:3px 9px;font-size:.71875rem;gap:4px;border-radius:7px}}@media (min-width:1024px){.header-nav-primary{gap:6px}.header-nav-utilities{gap:10px}.header-user-name{max-width:132px}.header-nav-link{padding:7px 14px}}@media (min-width:1280px){.header-nav-primary{gap:8px}.header-nav-utilities{gap:12px}}.mobile-menu{position:absolute;top:100%;left:0;right:0;padding:4px 0 16px;gap:0;background:rgba(255,255,255,.98);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid rgba(0,0,0,.08);box-shadow:0 8px 24px rgba(0,0,0,.1);z-index:50}.mobile-menu:not(.hidden){display:flex;flex-direction:column}.mobile-menu__section{padding:4px 0}.mobile-menu__section-label{display:block;padding:4px 18px 6px;font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:#9ca3af}.mobile-menu__divider{height:1px;margin:2px 16px;background:rgba(0,0,0,.06)}.mobile-menu__user-card{display:flex;align-items:center;gap:12px;margin:0 8px;padding:12px;border-radius:14px;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border:1px solid rgba(0,0,0,.05);text-decoration:none;transition:background .15s ease}.mobile-menu__user-card:active{background:linear-gradient(135deg,#f1f5f9,#e2e8f0)}.mobile-menu__avatar{width:40px;height:40px;border-radius:12px;background:linear-gradient(135deg,#eef2ff,#e0e7ff);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:#6366f1}.mobile-menu__avatar img{width:40px;height:40px;border-radius:12px;object-fit:contain;padding:4px}.mobile-menu__user-info{display:flex;flex-direction:column;gap:1px;min-width:0;flex:1}.mobile-menu__user-name{font-size:.9375rem;font-weight:700;color:#111827;letter-spacing:-.01em;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mobile-menu__user-sub{font-size:.75rem;color:#9ca3af;font-weight:500}.mobile-menu__points{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:8px;background:linear-gradient(135deg,#fef9c3,#fde68a);color:#92400e;font-size:.75rem;font-weight:700;flex-shrink:0}.mobile-menu__nav{display:flex;flex-direction:column;gap:1px;padding:0 4px}.mobile-menu__link{display:flex;align-items:center;gap:12px;padding:10px 14px;border-radius:12px;font-size:.875rem;font-weight:500;color:#374151;text-decoration:none;transition:background .12s ease}.mobile-menu__lang-trigger:active,.mobile-menu__link-icon,.mobile-menu__link:active{background:rgba(0,0,0,.04)}.mobile-menu__link-icon{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0;color:#6b7280}.mobile-menu__link-icon--accent{background:rgba(99,102,241,.08);color:#6366f1}.mobile-menu__lang-dropdown{margin:0 4px}.mobile-menu__lang-trigger{display:flex;align-items:center;gap:12px;width:100%;padding:10px 14px;border-radius:12px;font-size:.875rem;font-weight:500;color:#374151;transition:background .12s ease;cursor:pointer}.mobile-menu__lang-trigger .mobile-menu__link-icon{background:rgba(0,0,0,.04);padding:0}.mobile-menu__lang-trigger .mobile-menu__lang-flag{width:20px;height:20px}.mobile-menu__lang-current{flex:1;text-align:left}.mobile-menu__lang-code{font-size:.6875rem;font-weight:700;color:#9ca3af;letter-spacing:.04em}.mobile-menu__lang-chevron{width:14px;height:14px;color:#9ca3af;transition:transform .2s ease}.mobile-menu__lang-dropdown.is-open .mobile-menu__lang-chevron{transform:rotate(180deg)}.mobile-menu__lang-options{display:none;flex-direction:column;gap:1px;padding:4px 0 4px 52px}.mobile-menu__lang-dropdown.is-open .mobile-menu__lang-options{display:flex}.mobile-menu__lang-option{display:flex;align-items:center;gap:10px;padding:9px 14px;border-radius:10px;font-size:.8125rem;font-weight:500;color:#4b5563;transition:background .12s ease;cursor:pointer}.mobile-menu__lang-option:active{background:rgba(0,0,0,.04)}.mobile-menu__lang-option--active{color:#4f46e5;font-weight:600}.mobile-menu__lang-option-code{font-size:.6875rem;font-weight:600;color:#d1d5db;letter-spacing:.04em}.mobile-menu__lang-option--active .mobile-menu__lang-option-code{color:rgba(99,102,241,.4)}.mobile-menu__lang-flag{width:18px;height:18px;border-radius:50%;object-fit:cover;flex-shrink:0}