:root{--bg: #f4f8fb;--panel: #ffffff;--board-bg: #e7eef5;--cell-empty: #f6f9fc;--cell-border: #dbe5ee;--text: #25313f;--text-muted: #7c8a99;--accent: #34a8e0;--accent-strong: #1f8fc7;--danger: #fb7185;--shadow: 0 8px 24px rgba(40, 70, 100, .12)}*{box-sizing:border-box}html,body{margin:0;padding:0;height:100%}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,PingFang TC,Microsoft JhengHei,Roboto,Helvetica,Arial,sans-serif;background:var(--bg);color:var(--text);-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none;touch-action:manipulation;overscroll-behavior:none;overflow:hidden}.app{max-width:520px;margin:0 auto;padding:calc(env(safe-area-inset-top) + 12px) calc(env(safe-area-inset-right) + 16px) calc(env(safe-area-inset-bottom) + 16px) calc(env(safe-area-inset-left) + 16px);min-height:100dvh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:clamp(10px,2.5vh,16px)}.app-header{width:100%;display:flex;flex-direction:column;align-items:center;gap:12px}.app-title{margin:8px 0 0;font-size:clamp(20px,6vw,28px);font-weight:800;letter-spacing:.5px;color:var(--accent-strong)}.scoreboard{display:flex;gap:12px;width:100%;max-width:360px}.score-box{flex:1;background:var(--panel);border-radius:14px;padding:10px 14px;box-shadow:var(--shadow);display:flex;flex-direction:column;align-items:center}.score-label{font-size:12px;text-transform:uppercase;letter-spacing:1px;color:var(--text-muted)}.score-value{font-size:24px;font-weight:800;font-variant-numeric:tabular-nums}.play-area{width:100%;display:flex;flex-direction:column;align-items:center;gap:18px}.character{width:100%;display:flex;justify-content:center}.character-portrait{position:relative;display:flex;align-items:flex-end;justify-content:center;background:var(--panel);border-radius:22px;padding:6px 18px;box-shadow:var(--shadow);transition:transform .25s ease}.character-img{height:clamp(120px,21vh,220px);width:auto;display:block;-webkit-user-select:none;user-select:none;pointer-events:none;filter:drop-shadow(0 4px 8px rgba(40,70,100,.18))}.character-portrait--evolving{animation:char-pop 1.1s ease-out}.character-portrait--evolving:before{content:"";position:absolute;top:-10%;right:-10%;bottom:-10%;left:-10%;border-radius:50%;background:radial-gradient(circle,rgba(250,204,21,.55),rgba(251,113,133,.15) 60%,transparent 70%);animation:char-glow 1.1s ease-out forwards;z-index:-1}@keyframes char-pop{0%{transform:scale(1)}30%{transform:scale(1.18)}60%{transform:scale(.97)}to{transform:scale(1)}}@keyframes char-glow{0%{opacity:0;transform:scale(.6)}35%{opacity:1;transform:scale(1.1)}to{opacity:0;transform:scale(1.4)}}.character-evolve-msg{position:absolute;top:-10px;left:50%;transform:translate(-50%);white-space:nowrap;font-size:13px;font-weight:800;color:#fff;background:linear-gradient(120deg,#f472b6,#fb7185);padding:3px 10px;border-radius:999px;box-shadow:0 4px 10px #f472b666;animation:char-msg 1.1s ease-out forwards}@keyframes char-msg{0%{opacity:0;transform:translate(-50%,8px) scale(.8)}25%{opacity:1;transform:translate(-50%) scale(1)}80%{opacity:1}to{opacity:0;transform:translate(-50%,-8px) scale(.95)}}.character-bar{flex:1;min-width:0}.character-bar-label{display:flex;justify-content:space-between;font-size:13px;font-weight:700;color:var(--text);margin-bottom:5px}.character-bar-track{height:12px;border-radius:999px;background:#eef3f8;overflow:hidden;box-shadow:inset 0 1px 2px #00000014}.character-bar-fill{height:100%;border-radius:999px;background:linear-gradient(90deg,#f9a8d4,#f472b6,#c084fc);transition:width .4s ease}.character-bar-stage{margin-top:5px;font-size:11px;font-weight:700;letter-spacing:.5px;color:var(--text-muted);text-align:right}.board-wrap{position:relative;width:100%;display:flex;justify-content:center}.board{position:relative;width:min(92vw,36vh,390px);aspect-ratio:1 / 1;display:grid;grid-template-columns:repeat(8,1fr);grid-template-rows:repeat(8,1fr);gap:0;background:var(--board-bg);padding:6px;border-radius:16px;box-shadow:var(--shadow)}.cell{border-radius:6px;border:1px solid var(--cell-border);background:var(--cell-empty);transition:background .12s ease}.cell--filled{position:relative;border:none;border-radius:42%;box-shadow:inset 0 -4px 6px #0000002e,inset 0 3px 5px #ffffff73,inset 4px 0 6px #ffffff26,inset -4px 0 6px #00000014}.cell--filled:after{content:"";position:absolute;top:14%;left:16%;width:36%;height:28%;border-radius:50%;background:#ffffff8c;filter:blur(1px);pointer-events:none}.cell--preview{border-color:var(--accent)}.cell--preview-invalid{border-color:var(--danger);background:#fb71852e!important}.cell--placed{animation:pop .22s ease}@keyframes pop{0%{transform:scale(.6)}60%{transform:scale(1.08)}to{transform:scale(1)}}.clear-layer{position:absolute;top:6px;right:6px;bottom:6px;left:6px;pointer-events:none}.clear-cell{position:absolute;border-radius:6px;animation:clearFade .32s ease forwards}@keyframes clearFade{0%{opacity:1;transform:scale(1)}40%{opacity:1;transform:scale(1.05);filter:brightness(1.6)}to{opacity:0;transform:scale(.4)}}.tray{width:100%;display:flex;justify-content:space-around;align-items:center;gap:8px;min-height:clamp(70px,11vh,96px);background:var(--panel);border-radius:16px;padding:12px 8px;box-shadow:var(--shadow)}.tray-slot{flex:1;min-width:0;overflow:hidden;display:flex;align-items:center;justify-content:center;padding:6px;border-radius:12px;cursor:grab;touch-action:none;transition:transform .12s ease,background .12s ease}.tray-slot:active{cursor:grabbing}.tray-slot--selected{background:#34a8e01f;transform:scale(1.04)}.tray-slot--dragging{opacity:.25}.piece-cell{position:relative;border-radius:4px;background:transparent}.piece-cell--filled{border-radius:42%;box-shadow:inset 0 -3px 4px #0000002e,inset 0 2px 4px #ffffff73}.piece-cell--filled:after{content:"";position:absolute;top:14%;left:16%;width:36%;height:28%;border-radius:50%;background:#ffffff80;pointer-events:none}.drag-ghost{position:fixed;z-index:50;pointer-events:none;filter:drop-shadow(0 8px 12px rgba(40,70,100,.3));opacity:.92}.btn{font-family:inherit;font-size:15px;font-weight:700;border:none;border-radius:12px;padding:12px 22px;cursor:pointer;transition:transform .1s ease,background .15s ease}.btn:active{transform:scale(.97)}.btn--primary{background:var(--accent);color:#fff}.btn--primary:hover{background:var(--accent-strong)}.btn--ghost{background:var(--panel);color:var(--accent-strong);box-shadow:var(--shadow)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#1e2d3c73;display:flex;align-items:center;justify-content:center;padding:24px;z-index:100;animation:fadeIn .2s ease}.modal-card{background:var(--panel);border-radius:20px;padding:28px 32px;text-align:center;box-shadow:var(--shadow);width:100%;max-width:320px;animation:rise .25s ease}.modal-title{margin:0 0 16px;font-size:26px;color:var(--accent-strong)}.modal-line{margin:6px 0;font-size:16px;color:var(--text)}.modal-line strong{font-variant-numeric:tabular-nums}.modal-card .btn{margin-top:18px;width:100%}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes rise{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.kg-float{position:absolute;top:38%;left:50%;transform:translate(-50%,-50%);font-size:clamp(28px,8vw,52px);font-weight:900;color:#2fb36b;text-shadow:0 2px 0 #fff,0 4px 10px rgba(47,179,107,.35);pointer-events:none;z-index:40;animation:kgFloat 1s ease-out forwards}@keyframes kgFloat{0%{opacity:0;transform:translate(-50%,-30%) scale(.6)}25%{opacity:1;transform:translate(-50%,-55%) scale(1.1)}60%{opacity:1;transform:translate(-50%,-70%) scale(1)}to{opacity:0;transform:translate(-50%,-110%) scale(.95)}}.joylife-animation-overlay{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;z-index:999}.joylife-animation-text{font-size:clamp(40px,9vw,84px);font-weight:900;letter-spacing:.04em;background:linear-gradient(120deg,#34d399,#34a8e0,#c084fc);-webkit-background-clip:text;background-clip:text;color:transparent;text-shadow:0 8px 30px rgba(52,168,224,.25);animation:joylife-pop 1.2s ease-out forwards}.joylife-animation-text--grand{font-size:clamp(48px,12vw,120px);background:linear-gradient(120deg,#fbbf24,#fb7185,#c084fc)}.joylife-animation-sub{font-size:clamp(16px,4vw,24px);font-weight:800;color:#2fb36b;animation:joylife-pop 1.2s ease-out forwards}@keyframes joylife-pop{0%{transform:scale(.4);opacity:0}20%{transform:scale(1.15);opacity:1}45%{transform:scale(1);opacity:1}to{transform:scale(1.35);opacity:0}}
