:root{color:#3d273d;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;background:#fff6fb;font-family:Hiragino Maru Gothic ProN,Hiragino Sans,Yu Gothic,system-ui,sans-serif}*{box-sizing:border-box}body{min-width:320px;min-height:100vh;margin:0;overflow-x:hidden}button{font:inherit;cursor:pointer;-webkit-tap-highlight-color:transparent;border:0}a{color:inherit}.app-shell{background:radial-gradient(circle at 20% 12%,#fffffff5 0 12%,#0000 23%),radial-gradient(circle at 82% 0,#ffe29ccc 0 10%,#0000 25%),linear-gradient(145deg,#ffe0f1 0%,#fff8d8 46%,#dff6ff 100%);place-items:center;min-height:100vh;padding:18px;display:grid}.game-card{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#fffcffbd;border:3px solid #ffffffe6;border-radius:32px;flex-direction:column;gap:12px;width:min(100%,440px);min-height:min(900px,100vh - 28px);padding:18px;display:flex;position:relative;overflow:hidden;box-shadow:0 24px 70px #89588038,inset 0 0 0 1px #ff94c640}.game-card:before{content:"";pointer-events:none;background:#ffbdd959;border-radius:999px;width:180px;height:180px;position:absolute;inset:-80px -40px auto auto}.hero,.footer,.level-panel,.resource-top,.time-panel div:first-child,.actions{justify-content:space-between;align-items:center;gap:12px;display:flex}.hero{z-index:1;position:relative}.eyebrow{color:#b45b86;letter-spacing:.12em;margin:0 0 4px;font-size:.72rem;font-weight:800}h1,h2,p{margin:0}h1{letter-spacing:-.06em;font-size:clamp(1.55rem,7vw,2.25rem);line-height:1.02}h2{font-size:1.05rem}.lead,.level-panel p,.share-copy p,.resource small,.time-panel small,.footer{color:#76556f;font-size:.78rem}.level-badge{color:#fff;background:linear-gradient(160deg,#ff6fba,#8e7cff);border-radius:26px;flex:none;place-items:center;width:78px;height:78px;display:grid;transform:rotate(4deg);box-shadow:0 12px 24px #ac5bc64d}.level-badge span{font-size:.68rem;font-weight:800}.level-badge strong{font-size:2rem;line-height:.9}.level-badge:focus-visible{outline-offset:3px;outline:3px solid #ffffffe6}.stage{background:radial-gradient(circle at 50% 70%,#ffffffe6 0 24%,#0000 25%),linear-gradient(#d4f1ffcc,#ffe7f3e6);border-radius:28px;place-items:center;min-height:235px;display:grid;position:relative;overflow:hidden;box-shadow:inset 0 -14px 30px #ff88c624}.chibi{background:0 0;place-items:center;width:182px;height:190px;padding:0;transition:transform .14s;animation:2.9s ease-in-out infinite breathe;display:grid;position:relative}.chibi:active{transform:scale(.95)translateY(3px)}.chibi[data-pose=wave] img,.chibi[data-pose=ramen] img,.chibi[data-pose=sushi] img{animation:.65s happyWiggle}.chibi[data-pose=ramen] img,.chibi[data-pose=sushi] img{transform:translateY(2px)scale(1.04)}.chibi[data-pose=sleep] img{animation:1.4s ease-in-out infinite sleepyNod}.chibi img{object-fit:contain;filter:drop-shadow(0 18px 18px #81596f3d);image-rendering:auto;-webkit-user-select:none;user-select:none;width:min(100%,176px);height:min(100%,186px)}.sleep-mark{z-index:2;color:#786bff;font-weight:900;animation:1.8s ease-in-out infinite floatAway;position:absolute;top:2px;right:8px}.stage-copy{color:#80506f;text-align:center;background:#ffffffb8;border-radius:999px;padding:8px 12px;font-size:.78rem;font-weight:800;position:absolute;bottom:12px;left:14px;right:14px}.sparkle{color:#fff;text-shadow:0 2px 12px #ff53ab8c;font-size:2rem;animation:2.2s ease-in-out infinite twinkle;position:absolute}.sparkle-a{top:24px;left:32px}.sparkle-b{animation-delay:.7s;bottom:62px;right:34px}.gain-toast{z-index:3;color:#7d315f;pointer-events:none;background:#fff;border-radius:999px;padding:7px 10px;font-size:.78rem;font-weight:900;animation:.9s forwards popToast;position:absolute;box-shadow:0 10px 20px #754c6d2e}.resources{grid-template-columns:1fr;gap:8px;display:grid}.resource{background:#ffffffab;border:1px solid #ff90c347;border-radius:18px;padding:10px 12px}.resource-name,.resource strong{font-weight:900}.bar{background:#5a3b4f1a;border-radius:999px;height:9px;margin:7px 0 4px;overflow:hidden}.bar span{border-radius:inherit;min-width:4px;height:100%;transition:width .25s;display:block}.time-panel{background:#ffffffab;border:1px solid #a88cff3d;border-radius:18px;padding:10px 12px}.time-panel span,.time-panel strong{font-weight:900}.time-panel small{margin-top:4px;display:block}.actions button,.level-button,.share-actions button,.debug-actions button,.portfolio-link,.reset{border-radius:999px;font-weight:900;transition:transform .14s,filter .14s,opacity .14s}.actions button{color:#69344f;background:linear-gradient(#fff,#ffe7f2);flex:1;min-height:44px;box-shadow:0 8px 15px #955c8021}.actions button:active,.level-button:active,.share-actions button:active,.debug-actions button:active,.portfolio-link:active,.reset:active{transform:translateY(2px)scale(.98)}.level-panel{background:linear-gradient(135deg,#fff5aad1,#ffd3eae6);border-radius:22px;padding:13px}.missing-requirements{color:#8a4d62;background:#ffffff94;border-radius:999px;margin-top:7px;padding:5px 9px;font-size:.72rem;font-weight:900;display:inline-block}.next-evolution{color:#8a4d62;background:radial-gradient(circle at 50% 38%,#ffffffe6 0 24%,#0000 25%),linear-gradient(160deg,#ffffffa3,#ffecf9c2);border-radius:18px;flex:0 0 72px;place-items:center;gap:1px;min-width:72px;padding:6px 7px;font-size:.58rem;font-weight:900;display:grid;box-shadow:inset 0 0 0 1px #ff90c338}.next-evolution img{object-fit:contain;filter:drop-shadow(0 6px 7px #81596f29);opacity:.9;-webkit-user-select:none;user-select:none;width:42px;height:46px}.next-evolution strong{color:#7d315f;font-size:.68rem;line-height:1}.next-evolution small{color:#8b627e;text-align:center;text-overflow:ellipsis;white-space:nowrap;max-width:58px;font-size:.52rem;line-height:1.1;overflow:hidden}.level-button{color:#fff;background:linear-gradient(135deg,#ff65a8,#8e7cff);flex:none;min-width:124px;min-height:48px;padding:0 15px;box-shadow:0 12px 22px #8d5bc940}.level-button:disabled{cursor:not-allowed;opacity:.55;filter:grayscale(.15)}.evolution-strip{background:#ffffff94;border:1px solid #ff90c338;border-radius:20px;gap:8px;padding:11px 12px;display:grid}.evolution-strip-head,.evolution-list{justify-content:space-between;align-items:center;gap:8px;display:flex}.evolution-strip-head{color:#80506f;font-size:.72rem;font-weight:900}.evolution-strip-head strong{color:#b45b86}.evolution-strip-head small{color:#7d315f;white-space:nowrap;background:#ffffff9e;border-radius:999px;padding:3px 7px;font-size:.62rem;font-weight:900}.evolution-progress{background:#ffffff94;border-radius:999px;height:18px;position:relative;overflow:hidden;box-shadow:inset 0 0 0 1px #ff90c329}.evolution-progress span{border-radius:inherit;background:linear-gradient(90deg,#ff9aca,#8e7cff);position:absolute;inset:0 auto 0 0;box-shadow:0 0 14px #ff79bc3d}.evolution-progress small{z-index:1;color:#7d315f;text-shadow:0 1px #ffffffb8;place-items:center;height:100%;font-size:.62rem;font-weight:1000;display:grid;position:relative}.evolution-list{scrollbar-width:thin;padding-bottom:2px;overflow-x:auto}.evolution-chip{color:#87536e;background:#ffffff94;border-radius:16px;flex:1 0 58px;place-items:center;gap:2px;min-width:58px;padding:6px 5px;font-size:.62rem;font-weight:900;display:grid;box-shadow:inset 0 0 0 1px #ff90c329}.evolution-chip img{object-fit:contain;filter:drop-shadow(0 6px 7px #81596f24);-webkit-user-select:none;user-select:none;width:38px;height:42px}.evolution-chip.is-current{color:#fff;background:linear-gradient(145deg,#ff79bc,#8e7cff);box-shadow:0 8px 16px #8d5bc933}.evolution-chip.is-locked{opacity:.5;filter:grayscale(.25)}.evolution-gallery{background:#ffffff6b;border-radius:17px;grid-template-columns:repeat(10,minmax(0,1fr));gap:5px;padding:7px;display:grid;box-shadow:inset 0 0 0 1px #ff90c31f}.gallery-dot{color:#8b5b74;background:#ffffff8a;border-radius:12px;place-items:center;gap:1px;min-width:0;padding:4px 2px 3px;font-size:.54rem;font-weight:1000;display:grid;box-shadow:inset 0 0 0 1px #ff90c31f}.gallery-dot img{object-fit:contain;filter:drop-shadow(0 4px 5px #81596f1f);-webkit-user-select:none;user-select:none;width:25px;height:28px}.gallery-dot.is-current{color:#fff;background:linear-gradient(145deg,#ff79bc,#8e7cff);transform:translateY(-1px);box-shadow:0 6px 12px #8d5bc933}.gallery-dot.is-locked{opacity:.46;filter:grayscale(.28)}.share-panel{background:linear-gradient(135deg,#ffffffb8,#e4f3ffc7);border:1px solid #4d8bff2e;border-radius:22px;grid-template-columns:1fr auto;align-items:center;gap:10px 12px;padding:12px;display:grid}.share-copy{min-width:0}.share-copy h2{font-size:1rem}.share-copy p:last-child{margin-top:3px}.share-preview{color:#80506f;background:radial-gradient(circle at 50% 38%,#ffffffeb 0 24%,#0000 25%),linear-gradient(160deg,#fff2fadb,#e8f6ffdb);border-radius:18px;place-items:center;gap:2px;width:92px;min-width:92px;padding:7px 8px;font-size:.66rem;font-weight:900;display:grid;box-shadow:inset 0 0 0 1px #ff90c338}.share-preview img{object-fit:contain;filter:drop-shadow(0 8px 8px #81596f2e);-webkit-user-select:none;user-select:none;width:54px;height:60px}.share-preview strong{color:#7d315f;font-size:.78rem;line-height:1}.share-preview-progress{background:#ffffffbd;border-radius:999px;width:68px;height:7px;overflow:hidden;box-shadow:inset 0 0 0 1px #ff90c338}.share-preview-progress span{border-radius:inherit;background:linear-gradient(90deg,#ff79bc,#8e7cff);height:100%;display:block}.share-preview em{color:#6651a8;font-size:.54rem;font-style:normal;line-height:1}.share-preview small{color:#8b627e;text-align:center;text-overflow:ellipsis;white-space:nowrap;max-width:74px;font-size:.56rem;font-weight:800;line-height:1.15;overflow:hidden}.share-actions{flex-wrap:wrap;grid-column:1/-1;gap:8px;display:flex}.share-card-note{flex-wrap:wrap;grid-column:1/-1;gap:6px;margin-top:2px;display:flex}.share-card-note span,.share-note-button{color:#7d315f;background:#ffffffad;border-radius:999px;padding:5px 8px;font-size:.68rem;font-weight:900;box-shadow:inset 0 0 0 1px #ff90c32e}.share-note-button{color:#396777;background:linear-gradient(#fff,#e9fbff)}.share-steps{grid-column:1/-1;grid-template-columns:repeat(3,1fr);gap:6px;margin:0;padding:0;list-style:none;display:grid}.share-steps li{color:#6651a8;text-align:center;background:#ffffff9e;border-radius:12px;place-items:center;min-height:32px;padding:6px 8px 6px 26px;font-size:.66rem;font-weight:900;display:grid;position:relative;box-shadow:inset 0 0 0 1px #7e5db624}.share-steps li:before{content:counter(list-item);color:#fff;background:linear-gradient(135deg,#8e7cff,#ff79bc);border-radius:999px;place-items:center;width:16px;height:16px;font-size:.58rem;display:grid;position:absolute;top:50%;left:8px;transform:translateY(-50%)}.share-text-preview{color:#74506a;white-space:pre-wrap;background:#ffffffa8;border:1px solid #ff90c338;border-radius:16px;grid-column:1/-1;max-height:84px;margin-top:0;padding:9px 11px;font-size:.72rem;font-weight:700;line-height:1.45;overflow:auto}.share-text-preview strong{color:#9d3d76;margin-bottom:3px;font-size:.74rem;display:block}.share-text-preview-active{background:linear-gradient(135deg,#ffffffe0,#f4f1ffc7);border-color:#8e7cff57}.share-actions button{flex:118px;min-width:104px;min-height:42px;padding:0 10px;font-size:.78rem;box-shadow:0 9px 16px #62518626}.share-x{color:#fff;background:linear-gradient(135deg,#2d2a35,#8e7cff)}.share-copy-button{color:#7d315f;background:linear-gradient(#fff,#fff2fa)}.share-alt-copy{color:#396777;background:linear-gradient(#fff,#e9fbff)}.share-url-copy{color:#4d5f9b;background:linear-gradient(#fff,#eef2ff)}.share-asset-url-copy{color:#536b47;background:linear-gradient(#fff,#effce8)}.share-ready-copy{color:#6b3562;background:linear-gradient(#fff,#ffeaf7)}.share-bundle-copy{color:#7b4d12;background:linear-gradient(#fff,#fff4d8)}.share-card-copy{color:#6651a8;background:linear-gradient(#fff,#f0edff)}.share-image{color:#67344f;background:linear-gradient(#fff,#e9f6ff)}.debug-panel{background:#ffffff80;border:1px dashed #7e5db66b;border-radius:18px;justify-content:space-between;align-items:center;gap:10px;padding:10px 12px;display:flex}.debug-panel strong{color:#60406f;font-size:.86rem}.debug-actions{gap:6px;display:flex}.debug-actions button{color:#fff;background:linear-gradient(135deg,#7b6cff,#ff6fba);min-height:34px;padding:0 10px;box-shadow:0 7px 14px #7e5db629}.footer{padding-top:2px}.footer-actions{flex:none;align-items:center;gap:8px;display:flex}.portfolio-link{color:#5b4a9b;background:linear-gradient(#fff,#efecff);place-items:center;min-height:36px;padding:8px 12px;font-size:.78rem;text-decoration:none;display:inline-grid;box-shadow:0 7px 14px #6251861f}.portfolio-link:focus-visible{outline-offset:3px;outline:3px solid #8e7cff80}.reset{color:#8a4d6f;background:#ffffffb3;padding:8px 12px}.level-flash:after{content:"LEVEL UP! ✨";z-index:5;color:#fff;letter-spacing:-.05em;text-shadow:0 4px 20px #82399680;pointer-events:none;background:radial-gradient(circle,#ff8bd3db,#8e7cff61,#0000 72%);place-items:center;font-size:clamp(2rem,13vw,4rem);font-weight:1000;animation:1.25s forwards levelBurst;display:grid;position:absolute;inset:0}@keyframes breathe{0%,to{transform:translateY(0)rotate(-1deg)}50%{transform:translateY(-7px)rotate(1deg)}}@keyframes happyWiggle{0%,to{transform:rotate(0)scale(1)}28%{transform:rotate(-5deg)scale(1.04)}58%{transform:rotate(4deg)scale(1.02)}}@keyframes sleepyNod{0%,to{transform:translateY(0)rotate(-2deg)}50%{transform:translateY(5px)rotate(1deg)}}@keyframes floatAway{0%,to{opacity:.45;transform:translateY(0)}50%{opacity:1;transform:translateY(-8px)}}@keyframes twinkle{0%,to{opacity:.35;transform:scale(.75)rotate(0)}50%{opacity:1;transform:scale(1.1)rotate(18deg)}}@keyframes popToast{0%{opacity:0;transform:translate(-50%,10px)scale(.8)}18%{opacity:1}to{opacity:0;transform:translate(-50%,-34px)scale(1.05)}}@keyframes levelBurst{0%{opacity:0;transform:scale(.82)}20%{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(1.2)}}@media (height<=780px){.app-shell{padding:10px}.game-card{border-radius:26px;gap:9px;padding:13px}.stage{min-height:200px}.chibi{width:150px;height:158px}.chibi img{width:148px;height:156px}.resource{padding:8px 10px}.resource small,.share-copy p:last-child,.share-card-note,.share-steps,.share-text-preview{display:none}.evolution-strip,.share-panel,.debug-panel{padding:10px}.evolution-strip{gap:6px}.evolution-progress{height:16px}.evolution-progress small{font-size:.58rem}.evolution-chip{min-width:48px;padding:5px 4px}.evolution-chip img{width:30px;height:34px}.evolution-gallery{grid-template-columns:repeat(10,minmax(24px,1fr));gap:3px;padding:5px}.gallery-dot{border-radius:10px;font-size:.48rem}.gallery-dot img{width:20px;height:22px}.share-preview{width:82px;min-width:82px}.share-preview img{width:48px;height:52px}.share-preview-progress,.share-preview em,.share-preview small{display:none}}@media (width<=370px){.hero{align-items:flex-start}.level-badge{border-radius:22px;width:68px;height:68px}.level-panel{flex-direction:column;align-items:stretch}.level-button{width:100%}.share-actions,.debug-panel,.debug-actions,.footer{flex-direction:column;align-items:stretch}.footer-actions{justify-content:space-between}.share-steps{grid-template-columns:1fr}}
