*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #080f1c;--surface: #0f1a2e;--surface2: #142030;--border: #1c2e4a;--text: #e8f0fb;--text2: #7a8faf;--accent: #32d8df;--green: #55d68b;--amber: #ffad32;--coral: #ff6b6b;--r: 14px;font-family:Noto Sans SC,system-ui,sans-serif;-webkit-tap-highlight-color:transparent}html,body{height:100%;background:var(--bg);color:var(--text)}#root{height:100%}.shell{min-height:100dvh;max-width:480px;margin:0 auto;display:flex;flex-direction:column;position:relative}.shell:before{content:"";position:fixed;top:-120px;left:50%;transform:translate(-50%);width:500px;height:500px;background:radial-gradient(circle,rgba(50,216,223,.06) 0%,transparent 70%);pointer-events:none;z-index:0}.home{padding:20px 18px 48px;display:flex;flex-direction:column;gap:16px;position:relative;z-index:1}.challenge-banner{background:linear-gradient(135deg,#1a2e1a,#15341f);border:1.5px solid var(--green);border-radius:var(--r);padding:14px 16px;display:flex;align-items:center;justify-content:space-between;gap:12px}.challenge-banner strong{font-size:15px;color:var(--green)}.challenge-banner small{font-size:12px;color:var(--text2)}.challenge-banner button{background:var(--green);color:#0b1a0f;border:none;border-radius:8px;padding:10px 18px;font-weight:800;font-size:14px;cursor:pointer;white-space:nowrap;flex-shrink:0}.home-hero{text-align:center;padding:8px 0 4px}.hero-emoji{font-size:68px;line-height:1;display:inline-block;animation:heroFloat 3.5s ease-in-out infinite;filter:drop-shadow(0 6px 24px rgba(50,216,223,.4))}@keyframes heroFloat{0%,to{transform:translateY(0) rotate(-3deg)}50%{transform:translateY(-14px) rotate(3deg)}}.home-title{font-size:36px;font-weight:900;line-height:1.1;margin-top:12px;background:linear-gradient(130deg,#32d8df,#7baeff,#c47cff);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.home-sub{color:var(--text2);font-size:14px;margin-top:6px}.demo-row{display:flex;align-items:center;gap:18px;background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r);padding:14px 18px;animation:demoPulse 3s ease-in-out infinite alternate}@keyframes demoPulse{0%{border-color:var(--border);box-shadow:none}to{border-color:#32d8df66;box-shadow:0 0 20px #32d8df1a}}.demo-puzzle{display:grid;grid-template-columns:repeat(4,1fr);gap:3px;width:88px;flex-shrink:0;border-radius:8px;overflow:hidden}.demo-cell{aspect-ratio:1;border-radius:2px;animation:demoAppear .5s ease both}.demo-cell:nth-child(1){animation-delay:.05s}.demo-cell:nth-child(2){animation-delay:.1s}.demo-cell:nth-child(3){animation-delay:.15s}.demo-cell:nth-child(4){animation-delay:.2s}.demo-cell:nth-child(5){animation-delay:.25s}.demo-cell:nth-child(6){animation-delay:.3s}.demo-cell:nth-child(7){animation-delay:.35s}.demo-cell:nth-child(8){animation-delay:.4s}.demo-cell:nth-child(9){animation-delay:.45s}.demo-cell:nth-child(10){animation-delay:.5s}.demo-cell:nth-child(11){animation-delay:.55s}.demo-cell:nth-child(12){animation-delay:.6s}.demo-cell:nth-child(13){animation-delay:.65s}.demo-cell:nth-child(14){animation-delay:.7s}.demo-cell:nth-child(15){animation-delay:.75s}.demo-cell:nth-child(16){animation-delay:.8s}@keyframes demoAppear{0%{opacity:0;transform:scale(.4)}to{opacity:1;transform:scale(1)}}.demo-labels{display:flex;flex-direction:column;gap:6px;font-size:13px;color:var(--text2);line-height:1}.demo-labels span{display:flex;align-items:center;gap:4px}.daily-btn{width:100%;background:linear-gradient(135deg,#0c1e35,#0e2545);border:1.5px solid var(--accent);border-radius:var(--r);padding:16px 18px;cursor:pointer;display:flex;justify-content:space-between;align-items:center;text-align:left;color:var(--text);transition:background .15s,box-shadow .15s;box-shadow:0 0 #32d8df00}.daily-btn:hover{background:linear-gradient(135deg,#0e2545,#102e52);box-shadow:0 0 16px #32d8df2e}.daily-btn:active{background:#0b1c30}.daily-title{font-size:16px;font-weight:800;color:var(--accent);display:block}.daily-btn small{font-size:12px;color:var(--text2);margin-top:3px;display:block}.daily-arrow{font-size:22px;color:var(--accent)}.section-label{font-size:11px;color:var(--text2);font-weight:700;letter-spacing:.8px;text-transform:uppercase;margin-bottom:-6px}.diff-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.diff-card{border:2px solid;border-radius:var(--r);padding:18px 6px 16px;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:3px;transition:transform .12s,box-shadow .15s;color:var(--text);position:relative;overflow:hidden}.diff-card:active{transform:scale(.95)}.diff-easy{background:linear-gradient(160deg,#0b2015,#0f2d1c);border-color:var(--green)}.diff-easy:hover{box-shadow:0 4px 24px #55d68b40;transform:translateY(-2px)}.diff-easy .diff-icon{text-shadow:0 0 20px rgba(85,214,139,.7)}.diff-medium{background:linear-gradient(160deg,#1e1400,#2b1c00);border-color:var(--amber)}.diff-medium:hover{box-shadow:0 4px 24px #ffad3240;transform:translateY(-2px)}.diff-medium .diff-icon{text-shadow:0 0 20px rgba(255,173,50,.7)}.diff-hard{background:linear-gradient(160deg,#200a0a,#2e1010);border-color:var(--coral)}.diff-hard:hover{box-shadow:0 4px 24px #ff6b6b40;transform:translateY(-2px)}.diff-hard .diff-icon{text-shadow:0 0 20px rgba(255,107,107,.7)}.diff-icon{font-size:30px;margin-bottom:2px}.diff-card strong{font-size:14px;font-weight:800}.diff-sub{font-size:10px;color:var(--text2)}.diff-card small{font-size:10px;color:var(--text2);text-align:center;line-height:1.4;margin-top:2px}.seed-row{display:flex;gap:8px}.seed-input{flex:1;background:var(--surface);border:1.5px solid var(--border);border-radius:10px;padding:13px 14px;color:var(--text);font-size:16px;outline:none;transition:border-color .15s}.seed-input:focus{border-color:var(--accent)}.seed-input::placeholder{color:var(--text2);font-size:14px}.seed-go{background:linear-gradient(135deg,var(--accent),#28b8c0);color:#041820;border:none;border-radius:10px;padding:13px 22px;font-weight:800;font-size:15px;cursor:pointer;transition:opacity .15s}.seed-go:disabled{opacity:.3;cursor:default}.game{display:flex;flex-direction:column;min-height:100dvh;position:relative;z-index:1}.game-header{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;gap:10px;flex-shrink:0}.btn-icon{background:var(--surface);border:1.5px solid var(--border);border-radius:8px;color:var(--text);padding:8px 12px;font-size:16px;cursor:pointer;min-width:42px;text-align:center;transition:background .12s}.btn-icon:hover{background:var(--surface2)}.btn-icon:disabled{opacity:.28;cursor:default}.header-center{display:flex;flex-direction:column;align-items:center;gap:1px}.diff-tag{font-size:13px;font-weight:700;color:var(--accent)}.fill-tag{font-size:12px;color:var(--text2)}.header-right{display:flex;align-items:center;gap:8px}.timer{font-size:20px;font-weight:900;color:var(--text);font-family:Chakra Petch,monospace;min-width:44px;text-align:center}.timer-danger{color:var(--coral);animation:pulse .7s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.45}}.progress-bar{height:3px;background:var(--border);flex-shrink:0}.progress-fill{height:100%;background:linear-gradient(90deg,var(--accent),#7baeff);transition:width .3s ease}.grid-wrap{flex:1;display:flex;align-items:center;justify-content:center;padding:10px 16px;min-height:0}.grid{display:grid;grid-template-columns:repeat(var(--cols),1fr);gap:4px;width:min(calc(100vw - 32px),400px);aspect-ratio:var(--cols) / var(--rows)}.cell{background:var(--surface);border:1.5px solid var(--border);border-radius:8px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .1s,border-color .1s;position:relative;-webkit-user-select:none;user-select:none;touch-action:manipulation}.cell.hoverable:hover{border-color:var(--accent);background:#0d2035}.cell.filled{cursor:default}.cell.ghost{border-style:dashed}.cell.popping{animation:cellPop .38s cubic-bezier(.34,1.56,.64,1) both}@keyframes cellPop{0%{transform:scale(.45);opacity:.4}60%{transform:scale(1.12)}to{transform:scale(1);opacity:1}}.cell.filled:after{content:"";position:absolute;top:0;left:0;right:55%;bottom:55%;background:#ffffff2e;border-radius:6px 0 0;pointer-events:none}.cell-emoji{font-size:clamp(14px,4vw,24px);pointer-events:none}.ghost-emoji{opacity:.6}.controls{display:flex;align-items:center;gap:8px;padding:6px 14px;flex-shrink:0}.rotate-btn{background:var(--surface2);border:1.5px solid var(--border);border-radius:10px;color:var(--text);padding:10px 14px;font-size:14px;font-weight:700;cursor:pointer;flex:1;transition:background .12s,transform .1s}.rotate-btn:active{background:var(--border);transform:scale(.95)}.sel-hint{flex:1.2;display:flex;flex-direction:column;align-items:center;gap:1px}.sel-emoji{font-size:22px}.sel-name{font-size:11px;color:var(--text2);font-weight:600;text-align:center}.sel-done{color:var(--green)}.shape-preview-wrap{display:flex;flex-direction:column;align-items:center;gap:2px;padding:4px 0 0;flex-shrink:0}.shape-row{display:flex;gap:2px}.shape-cell{width:10px;height:10px;border-radius:2px}.tray{flex-shrink:0}.tray-label{font-size:11px;color:var(--text2);padding:6px 16px 4px}.tray-scroll{display:flex;gap:8px;overflow-x:auto;padding:4px 16px 14px;scrollbar-width:none}.tray-scroll::-webkit-scrollbar{display:none}.piece-btn{flex-shrink:0;background:var(--surface);border:2px solid var(--border);border-radius:12px;padding:8px 10px 6px;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:2px;min-width:64px;position:relative;transition:border-color .12s,transform .1s,background .12s;color:var(--text)}.piece-btn:active{transform:scale(.93)}.piece-btn.selected{border-color:var(--piece-color);background:color-mix(in srgb,var(--piece-color) 12%,var(--surface));box-shadow:0 0 12px color-mix(in srgb,var(--piece-color) 30%,transparent)}.piece-btn.done{opacity:.28;cursor:default}.piece-shape-preview{display:flex;flex-direction:column;align-items:center;gap:2px;min-height:22px;justify-content:center;margin-bottom:1px}.piece-shape-row{display:flex;gap:2px}.piece-shape-cell{width:7px;height:7px;border-radius:1.5px;transition:background .15s}.piece-emoji{font-size:20px}.piece-name{font-size:9px;color:var(--text2);white-space:nowrap}.piece-check{position:absolute;top:4px;right:6px;font-size:11px;color:var(--green);font-weight:900}.seed-display{text-align:center;font-size:11px;color:var(--text2);opacity:.65;padding:4px 16px 14px;flex-shrink:0}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#040812e6;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;z-index:100;padding:20px}.overlay-card{background:var(--surface);border:1.5px solid var(--border);border-radius:24px;padding:32px 24px 28px;width:100%;max-width:360px;display:flex;flex-direction:column;align-items:center;gap:14px;text-align:center;position:relative;overflow:hidden}.won-card{border-color:var(--green);box-shadow:0 0 40px #55d68b26}.fail-card{border-color:var(--amber);box-shadow:0 0 40px #ffad321f}.confetti-box{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;overflow:hidden;border-radius:24px;z-index:0}.conf-item{position:absolute;top:-24px;animation:confFall linear both}@keyframes confFall{0%{transform:translateY(0) rotate(0);opacity:1}80%{opacity:1}to{transform:translateY(420px) rotate(720deg);opacity:0}}.overlay-card>*:not(.confetti-box){position:relative;z-index:1}.overlay-big{font-size:56px;line-height:1}.overlay-card h2{font-size:26px;font-weight:900}.overlay-card>p{font-size:14px;color:var(--text2)}.stat-row{display:flex;gap:28px;justify-content:center}.stat-row>div{display:flex;flex-direction:column;align-items:center;gap:2px}.stat-row b{font-size:28px;font-weight:900;color:var(--accent)}.stat-row span{font-size:12px;color:var(--text2)}.seed-chip{font-size:14px;font-weight:700;color:var(--accent);background:color-mix(in srgb,var(--accent) 10%,var(--surface));border:1px solid color-mix(in srgb,var(--accent) 30%,transparent);border-radius:20px;padding:6px 18px}.share-block{display:flex;flex-direction:column;align-items:center;gap:10px;width:100%}.qr-img{width:160px;height:160px;border-radius:12px;border:4px solid white}.share-hint{font-size:13px;color:var(--text2)}.overlay-actions{display:flex;flex-direction:column;gap:8px;width:100%}.primary-btn{width:100%;background:linear-gradient(135deg,var(--accent),#28b8c0);color:#041820;border:none;border-radius:12px;padding:14px;font-size:16px;font-weight:800;cursor:pointer;transition:opacity .15s,transform .1s}.primary-btn:hover{opacity:.9}.primary-btn:active{transform:scale(.97)}.primary-btn:disabled{opacity:.4;cursor:default}.secondary-btn{width:100%;background:var(--surface2);border:1.5px solid var(--border);border-radius:12px;padding:12px;font-size:14px;font-weight:700;color:var(--text);cursor:pointer;transition:background .12s}.secondary-btn:hover{background:var(--border)}.ghost-btn{background:none;border:none;color:var(--text2);font-size:14px;cursor:pointer;padding:8px}.toast{position:fixed;bottom:110px;left:50%;transform:translate(-50%);background:#1a2840ee;border:1.5px solid var(--border);border-radius:24px;padding:10px 22px;font-size:14px;font-weight:600;z-index:200;white-space:nowrap;pointer-events:none;animation:toastIn .18s ease}@keyframes toastIn{0%{opacity:0;transform:translate(-50%) translateY(8px)}to{opacity:1;transform:translate(-50%) translateY(0)}}@media(max-height:700px){.grid-wrap{padding:6px 14px}.controls{padding:4px 14px}.home{padding-top:14px}.hero-emoji{font-size:48px}.home-title{font-size:28px}}
