:root{--bg:#eef6ec;--surface:#ffffff;--paper:#e3efe0;--slot:#d6e6d3;--line:#cfe2cc;--green:#6cae84;--green-deep:#3f8460;--blush:#f0c5bb;--mint:#57c08a;--text:#324a3c;--muted:#7d978a;--shadow:0 14px 28px -14px rgba(60,120,85,.35)}*{box-sizing:border-box}html,body{margin:0;height:100%;overscroll-behavior:none}body{background:radial-gradient(1100px 560px at 78% -12%,#ffffff 0%,transparent 60%),radial-gradient(820px 480px at -5% 108%,#dff0db 0%,transparent 58%),var(--bg);color:var(--text);font-family:Inter,system-ui,sans-serif;-webkit-font-smoothing:antialiased;overflow-x:hidden}.app{max-width:760px;margin:0 auto;padding:18px 16px 48px}.topbar{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-bottom:14px}.brand{display:flex;flex-direction:column;line-height:1}.brand h1{font-family:"Baloo 2",cursive;font-weight:800;font-size:30px;margin:0;letter-spacing:.2px;color:var(--green-deep)}.brand h1 span{color:var(--green)}.brand p{margin:6px 0 0;font-size:12.5px;color:var(--muted)}.stats{display:flex;gap:10px}.stat{background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:8px 12px;min-width:62px;text-align:center;box-shadow:var(--shadow)}.stat b{display:block;font-family:"Baloo 2",cursive;font-size:18px;color:var(--green-deep)}.stat small{display:block;font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-top:2px}.controls{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:18px}button,select,label.btn{font-family:Inter,sans-serif;font-size:13px;font-weight:500;color:var(--text);background:var(--surface);border:1px solid var(--line);border-radius:11px;padding:9px 13px;cursor:pointer;transition:.15s border-color,.15s transform,.15s background}button:hover,select:hover,label.btn:hover{border-color:var(--green)}button:active{transform:translateY(1px)}button.primary{background:var(--green);color:#fff;border-color:var(--green);font-weight:600}button.primary:hover{filter:brightness(1.04)}select{-webkit-appearance:none;-moz-appearance:none;appearance:none;padding-right:13px}:focus-visible{outline:2px solid var(--green);outline-offset:2px}input[type=file]{display:none}.stage{position:relative;width:100%;user-select:none;-webkit-user-select:none}.board{position:absolute;border-radius:16px;background:var(--paper);box-shadow:inset 0 0 0 1px var(--line),inset 0 2px 14px #46785a1f;overflow:hidden}.slot-grid{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;transition:opacity .6s ease}.slot{position:absolute;border:1px dashed #5a8f6f33;border-radius:7px}.stage.complete .slot-grid{opacity:0}.stage.complete .piece{border-radius:0;box-shadow:none;transition:box-shadow .6s ease,border-radius .6s ease}.stage.complete .piece:after{box-shadow:none;border-radius:0}.hint-tile{position:absolute;border-radius:7px;background-repeat:no-repeat;pointer-events:none;box-shadow:0 0 0 2px var(--green),inset 0 0 0 1px #fff6;opacity:.7;animation:hintPulse .35s ease}@keyframes hintPulse{0%{opacity:0;transform:scale(.92)}to{opacity:.7;transform:scale(1)}}.tray{position:absolute;border-radius:16px;background:radial-gradient(circle at 10px 10px,#d3e8cf 1.6px,transparent 1.7px) 0 0/22px 22px,var(--surface);box-shadow:inset 0 0 0 1px var(--line)}.tray-label{position:absolute;top:8px;left:14px;font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);pointer-events:none}.piece{position:absolute;border-radius:7px;background-repeat:no-repeat;cursor:grab;touch-action:none;box-shadow:0 6px 14px -6px #2d5a3c73,inset 0 0 0 1px #fff6;transition:box-shadow .15s,transform .2s cubic-bezier(.2,.9,.25,1.1),left .2s,top .2s;will-change:left,top,transform}.piece:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:7px;box-shadow:inset 0 1px 1px #ffffff73,inset 0 -2px 5px #28503729;pointer-events:none}.piece.dragging{cursor:grabbing;z-index:999;transition:none;box-shadow:0 22px 34px -12px #285a3c80,inset 0 0 0 1px #ffffff80}.piece.placed{cursor:default;box-shadow:inset 0 0 0 1px #78a08759}.piece.snap{animation:settle .4s ease}@keyframes settle{0%{box-shadow:0 0 0 3px var(--green),0 16px 26px -12px #285a3c80}to{box-shadow:inset 0 0 0 1px #78a08759}}.toast{position:fixed;left:50%;top:18px;transform:translate(-50%,-24px);background:var(--surface);color:var(--green-deep);border:1px solid var(--line);border-radius:999px;padding:11px 20px;font-family:"Baloo 2",cursive;font-weight:700;font-size:15px;box-shadow:var(--shadow);opacity:0;pointer-events:none;z-index:1002;transition:opacity .3s,transform .3s cubic-bezier(.2,.9,.25,1.2);white-space:nowrap}.toast.show{opacity:1;transform:translate(-50%)}.terry{position:fixed;left:18px;bottom:18px;z-index:998;pointer-events:none;display:flex;flex-direction:column;align-items:flex-start;gap:10px}.bubble{max-width:230px;background:var(--surface);border:1px solid var(--line);border-radius:16px 16px 16px 4px;padding:11px 15px;font-size:13.5px;font-weight:500;color:var(--text);line-height:1.35;box-shadow:var(--shadow);position:relative;opacity:0;transform:translateY(8px) scale(.96);transform-origin:bottom left;transition:opacity .25s,transform .3s cubic-bezier(.2,.9,.25,1.25)}.bubble:after{content:"";position:absolute;left:16px;bottom:-7px;width:14px;height:14px;background:var(--surface);border-right:1px solid var(--line);border-bottom:1px solid var(--line);transform:rotate(45deg);border-radius:0 0 3px}.bubble.show{opacity:1;transform:translateY(0) scale(1)}.terry-face{width:82px;height:82px;border-radius:50%;flex:none;object-fit:cover;border:3px solid #fff;background:#d9e8f4;box-shadow:var(--shadow);animation:bob 3.4s ease-in-out infinite}.terry-face.talk{animation:bob 3.4s ease-in-out infinite,nod .4s ease}@keyframes bob{0%,to{transform:translateY(0)}50%{transform:translateY(-5px)}}@keyframes nod{0%{transform:translateY(0) rotate(0)}50%{transform:translateY(2px) rotate(-4deg)}to{transform:translateY(0) rotate(0)}}.win{position:fixed;top:0;right:0;bottom:0;left:0;display:none;place-items:center;z-index:1000;background:#e1f0e1b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.win.show{display:grid}.card{background:var(--surface);border:1px solid var(--line);border-radius:20px;padding:30px 34px;text-align:center;box-shadow:var(--shadow);max-width:320px;animation:pop .35s cubic-bezier(.2,.9,.25,1.2)}@keyframes pop{0%{transform:scale(.9);opacity:0}to{transform:scale(1);opacity:1}}.card{max-width:360px}.card h2{font-family:"Baloo 2",cursive;font-size:26px;margin:0 0 6px;color:var(--green-deep)}.card p{color:var(--muted);font-size:14px;margin:0 0 16px}.card .big{color:var(--green);font-weight:700}.lb-form{display:flex;flex-direction:column;gap:8px;margin:0 0 14px}.lb-label{font-size:12.5px;color:var(--muted);font-weight:600}.lb-form input{font-family:Inter,sans-serif;font-size:15px;color:var(--text);text-align:center;background:var(--paper);border:1px solid var(--line);border-radius:11px;padding:11px 12px}.lb-form input:focus{outline:none;border-color:var(--green)}.lb-form .primary{border-radius:11px;padding:11px}.lb-error{color:#c2685a;font-size:12.5px;margin:0}.lb-note{font-size:12.5px;color:var(--muted);margin:0 0 14px}.lb{margin:0 0 16px;text-align:left}.lb-title{font-family:"Baloo 2",cursive;font-weight:700;font-size:14px;color:var(--green-deep);margin-bottom:6px;text-align:center}.lb-list{list-style:none;margin:0;padding:0;max-height:188px;overflow-y:auto;border:1px solid var(--line);border-radius:12px}.lb-list li{display:flex;align-items:center;gap:8px;padding:7px 11px;font-size:13px;border-bottom:1px solid var(--line)}.lb-list li:last-child{border-bottom:0}.lb-list li.me{background:#e7f4ec}.lb-rank{width:20px;color:var(--muted);font-weight:600;text-align:right}.lb-name{flex:1;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.lb-time{font-family:"Baloo 2",cursive;color:var(--green-deep);font-weight:700}.lb-moves{color:var(--muted);font-size:11.5px;min-width:34px;text-align:right}.win-actions{display:flex;gap:8px;justify-content:center;flex-wrap:wrap}.win-actions button{flex:1;min-width:120px}#fx{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:1001;display:none}.greet,.lb-modal{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1003;display:none;place-items:center;padding:20px;background:#e1f0e1b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.greet.show,.lb-modal.show{display:grid}.greet-card{background:var(--surface);border:1px solid var(--line);border-radius:20px;padding:26px 30px 24px;text-align:center;box-shadow:var(--shadow);max-width:330px;animation:pop .35s cubic-bezier(.2,.9,.25,1.2)}.greet-face{width:84px;height:84px;border-radius:50%;object-fit:cover;border:3px solid #fff;background:#d9e8f4;box-shadow:var(--shadow);margin:0 auto 12px;display:block;animation:bob 3.4s ease-in-out infinite}.greet-bubble{font-size:15px;line-height:1.4;color:var(--text);margin:0 0 18px}.greet-bubble strong{color:var(--green-deep)}.greet-card .primary{border-radius:12px;padding:11px 22px;font-family:"Baloo 2",cursive;font-size:16px}.gate{position:fixed;top:0;right:0;bottom:0;left:0;z-index:2000;display:grid;place-items:center;padding:20px;background:repeating-linear-gradient(45deg,#6cae84 0,#6cae84 26px,#5ba074 26px,#5ba074 52px),repeating-linear-gradient(-45deg,rgba(255,255,255,.1) 0 26px,transparent 26px 52px),var(--green-deep);background-blend-mode:multiply,screen,normal;transition:opacity .6s ease,transform .6s cubic-bezier(.4,0,.2,1)}.gate:before,.gate:after{content:"";position:fixed;pointer-events:none;z-index:1;background:linear-gradient(#f6d9cf,#f0c5bb);box-shadow:0 0 22px #28503740}.gate:before{left:50%;top:0;bottom:0;width:62px;transform:translate(-50%)}.gate:after{top:50%;left:0;right:0;height:62px;transform:translateY(-50%)}.gate.opening{opacity:0;transform:scale(1.06);pointer-events:none}.gift{position:relative;z-index:2;width:min(360px,92vw);text-align:center;background:var(--surface);border:1px solid var(--line);border-radius:22px;padding:30px 28px 26px;box-shadow:0 26px 50px -20px #14321e8c;animation:pop .4s cubic-bezier(.2,.9,.25,1.2)}.gift .bow{font-size:46px;line-height:1;margin-bottom:6px}.gift h2{font-family:"Baloo 2",cursive;font-size:24px;margin:0 0 4px;color:var(--green-deep)}.gift p{margin:0 0 18px;font-size:13.5px;color:var(--muted)}.gift form{display:flex;flex-direction:column;gap:10px}.gift input[type=password]{display:block;width:100%;font-family:Inter,sans-serif;font-size:15px;color:var(--text);background:var(--paper);border:1px solid var(--line);border-radius:12px;padding:12px 14px;text-align:center;letter-spacing:.04em}.gift input[type=password]:focus{outline:none;border-color:var(--green)}.gift button.unwrap{background:var(--green);color:#fff;border:1px solid var(--green);border-radius:12px;font-family:"Baloo 2",cursive;font-weight:700;font-size:16px;padding:12px;cursor:pointer}.gift button.unwrap:hover{filter:brightness(1.04)}.gift .hint{min-height:16px;margin:2px 0 0;font-size:12.5px;color:var(--blush);font-weight:600}.gift.shake{animation:shake .4s}@keyframes shake{0%,to{transform:translate(0)}20%{transform:translate(-8px)}40%{transform:translate(7px)}60%{transform:translate(-5px)}80%{transform:translate(4px)}}@media (max-width:480px){.brand h1{font-size:25px}.stat{min-width:54px;padding:7px 9px}.terry{left:10px;bottom:10px}.terry-face{width:66px;height:66px}.bubble{max-width:190px;font-size:12.5px}}@media (prefers-reduced-motion:reduce){*{animation-duration:.01ms!important;transition-duration:.01ms!important}}
