:root{--paper:#f4efe5;--paper-deep:#e9dfcf;--card:#fffdf8;--ink:#20242d;--muted:#6f706d;--line:#d8cebd;--orange:#f26b3a;--orange-dark:#c94720;--purple:#6055a5;--blue:#3d7599;--green:#26815c;--red:#c64a3d;--yellow:#f1c75b;--shadow:0 14px 34px #3d30231f;--font-display:"Arial Black", "PingFang SC", "Microsoft YaHei", sans-serif;--font-body:Inter, "PingFang SC", "Microsoft YaHei", sans-serif}*{box-sizing:border-box}html{background:#d9d1c4;min-width:320px;min-height:100%}body{min-width:320px;min-height:100vh;color:var(--ink);font-family:var(--font-body);background-color:#d9d1c4;background-image:linear-gradient(90deg,#ffffff38 1px,#0000 1px),linear-gradient(#ffffff2e 1px,#0000 1px),none;background-position:0 0,0 0,0 0;background-repeat:repeat,repeat,repeat;background-size:24px 24px;background-attachment:scroll,scroll,scroll;background-origin:padding-box,padding-box,padding-box;background-clip:border-box,border-box,border-box;margin:0}button,input,textarea{font:inherit}button{color:inherit}button:focus-visible{outline-offset:2px;outline:3px solid #f26b3a59}.app-shell{background:var(--paper);max-width:430px;min-height:100vh;margin:0 auto;position:relative;overflow:hidden;box-shadow:0 0 45px #271f1733}.app-shell:before{z-index:0;pointer-events:none;content:"";opacity:.23;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 160 160' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.12'/%3E%3C/svg%3E");width:min(430px,100vw);height:100vh;position:fixed;top:0}.app-shell__content{z-index:2;min-height:100vh;position:relative}.app-shell__glow{filter:blur(1px);opacity:.18;border-radius:50%;position:absolute}.app-shell__glow--one{background:var(--orange);width:230px;height:230px;top:-90px;right:-80px}.app-shell__glow--two{background:var(--purple);width:220px;height:220px;top:380px;left:-110px}.page{min-height:100vh;padding:18px 18px 36px}.eyebrow{color:var(--orange-dark);letter-spacing:2px;text-transform:uppercase;font-size:11px;font-weight:900}.top-bar{border-bottom:1px solid var(--line);grid-template-columns:42px 1fr 58px;align-items:center;min-height:56px;margin-bottom:18px;display:grid}.top-bar__title{flex-direction:column;align-items:center;line-height:1.15;display:flex}.top-bar__title span{color:var(--muted);letter-spacing:1.5px;text-transform:uppercase;font-size:9px;font-weight:800}.top-bar__title strong{margin-top:3px;font-size:15px}.top-bar__badge{border:1px solid var(--orange);color:var(--orange-dark);text-align:center;padding:4px;font-size:9px;font-weight:900;transform:rotate(3deg)}.top-bar__spacer{width:42px}.icon-button{border:1px solid var(--line);cursor:pointer;background:#fffdf8b3;border-radius:50%;place-items:center;width:38px;height:38px;padding:0;font-size:20px;display:inline-grid}.button{cursor:pointer;border:0;border-radius:12px;min-height:48px;padding:12px 16px;font-weight:850;transition:transform .16s,box-shadow .16s,opacity .16s}.button:active{transform:translateY(1px)scale(.99)}.button:disabled{cursor:default;opacity:.55}.button--primary{color:#fff;background:var(--ink);box-shadow:0 8px 18px #20242d2b}.button--secondary{border:1px solid var(--line);background:var(--card)}.button--text{min-height:40px;color:var(--muted);background:0 0}.button--ad{color:#684711;background:#fff2c8;border:1px solid #d8a93c;justify-content:center;align-items:center;gap:7px;display:flex}.button--ad span{color:#fff;background:#d99d1c;border-radius:50%;place-items:center;width:20px;height:20px;font-size:9px;display:grid}.home-page{padding-top:28px}.home-hero{border:1px solid var(--line);border-top:5px solid var(--ink);box-shadow:var(--shadow);background:#fffdf8b8;padding:24px 20px 22px;position:relative}.home-hero:after{content:"审定";color:#c64a3db3;text-align:center;border:3px double #c64a3d8c;border-radius:50%;width:54px;height:54px;font-weight:900;line-height:48px;position:absolute;bottom:18px;right:18px;transform:rotate(-12deg)}.home-hero__seal{color:#fff;background:var(--purple);letter-spacing:1px;padding:7px 10px;font-size:10px;font-weight:900;line-height:1.05;position:absolute;top:-12px;right:16px;transform:rotate(4deg)}.home-hero h1{font-family:var(--font-display);letter-spacing:-3px;margin:14px 0 8px;font-size:clamp(44px,14vw,58px);line-height:.95}.home-hero h1 em{color:var(--orange);font-style:normal}.home-hero>p{color:var(--muted);margin:0 0 24px;font-size:15px;font-weight:700}.home-hero__case{border-left:4px solid var(--orange);background:var(--paper-deep);flex-direction:column;width:calc(100% - 64px);padding:12px 14px;display:flex}.home-hero__case span,.home-hero__case small{color:var(--muted);font-size:10px}.home-hero__case strong{margin:2px 0;font-size:17px}.home-actions{gap:10px;margin:18px 0;display:grid}.button--hero{color:#fff;background:var(--orange);justify-content:space-between;align-items:center;min-height:72px;padding:16px 18px;display:flex;box-shadow:0 10px 22px #c9472040}.button--hero span{font-family:var(--font-display);font-size:22px}.button--hero b{font-size:11px}.progress-ticket{background:#fffdf89e;border:1px dashed #b4a58f;grid-template-columns:1fr 1fr;gap:12px;padding:16px;display:grid;position:relative;overflow:hidden}.progress-ticket>div{flex-direction:column;display:flex}.progress-ticket span{color:var(--muted);font-size:10px;font-weight:800}.progress-ticket strong{font-size:26px}.progress-ticket small{color:var(--muted);margin-left:4px;font-size:10px}.progress-ticket__bar{background:var(--paper-deep);border-radius:10px;grid-column:1/-1;height:5px}.progress-ticket__bar span{border-radius:inherit;background:var(--orange);height:100%;transition:width .3s}.how-to-play{margin-top:26px}.section-heading span{color:var(--orange-dark);letter-spacing:1.8px;font-size:9px;font-weight:900}.section-heading h2{font-family:var(--font-display);margin:3px 0 12px;font-size:19px}.how-to-play__steps{grid-template-columns:repeat(3,1fr);gap:8px;display:grid}.how-to-play__steps div{border:1px solid var(--line);background:var(--card);flex-direction:column;justify-content:space-between;min-height:76px;padding:10px;display:flex}.how-to-play__steps b{color:var(--orange);font-size:10px}.how-to-play__steps span{font-weight:900}.reset-link{color:var(--muted);cursor:pointer;background:0 0;border:0;margin:24px auto 0;font-size:11px;text-decoration:underline;display:block}.page-intro{margin:24px 4px 22px}.page-intro h1,.level-list-hero h1{font-family:var(--font-display);letter-spacing:-1.2px;margin:7px 0 9px;font-size:31px;line-height:1.05}.page-intro p{max-width:340px;color:var(--muted);margin:0;font-size:13px;line-height:1.7}.template-list,.level-list{gap:10px;display:grid}.template-card{border:1px solid var(--line);opacity:.66;text-align:left;cursor:pointer;background:#fffdf8b3;border-radius:3px;grid-template-columns:54px 1fr 28px;align-items:center;gap:12px;width:100%;min-height:106px;padding:14px;display:grid}.template-card.is-available{border-left:5px solid var(--orange);opacity:1;box-shadow:0 8px 20px #3d302314}.template-card__emoji{border:1px solid var(--line);background:var(--paper);border-radius:50%;place-items:center;width:50px;height:50px;font-size:25px;display:grid}.template-card__body{flex-direction:column;min-width:0;display:flex}.template-card__heading{justify-content:space-between;align-items:center;gap:8px;display:flex}.template-card__heading strong{font-size:17px}.template-card__heading em{color:var(--muted);background:var(--paper-deep);white-space:nowrap;border-radius:3px;padding:3px 6px;font-size:9px;font-style:normal}.template-card__body b{color:var(--orange-dark);margin:5px 0 3px;font-size:11px}.template-card__body small{color:var(--muted);text-overflow:ellipsis;white-space:nowrap;font-size:10px;line-height:1.45;overflow:hidden}.template-card__arrow{color:var(--orange);font-size:20px}.level-list-hero{border:1px solid var(--line);color:#fff;background:var(--ink);justify-content:space-between;align-items:end;margin-bottom:18px;padding:18px;display:flex}.level-list-hero>div>span{color:#f5b18d;letter-spacing:1.2px;font-size:9px;font-weight:900}.level-list-hero h1{margin-bottom:12px;font-size:25px}.level-list-hero p{color:#c6c8cd;margin:0;font-size:11px}.level-list-hero__meter{text-align:center;border:1px solid #555963;flex-direction:column;min-width:70px;padding:10px;display:flex}.level-list-hero__meter strong{font-size:20px}.level-list-hero__meter span{color:#c6c8cd;font-size:9px}.level-list-tip{background:#fffdf89e;border:1px dashed #b8a991;align-items:center;gap:10px;margin:-5px 0 14px;padding:10px 12px;display:flex}.level-list-tip span{color:#fff;background:var(--purple);border-radius:3px;flex:none;padding:4px 7px;font-size:9px;font-weight:900}.level-list-tip p{color:var(--muted);margin:0;font-size:9px;line-height:1.45}.level-list{grid-template-columns:repeat(2,minmax(0,1fr))}.level-card{border:1px solid var(--line);border-top:4px solid var(--ink);background:var(--card);text-align:left;border-radius:4px;flex-direction:column;min-width:0;min-height:176px;padding:12px 12px 10px;display:flex;box-shadow:3px 4px #ded3c3}.level-card.is-passed{border-top-color:var(--green)}.level-card.is-locked{background:repeating-linear-gradient(-45deg,#867d710d,#867d710d 8px,#0000 8px 16px),#eee9df;border-top-color:#938b80}.level-card__top{justify-content:space-between;align-items:center;gap:6px;display:flex}.level-card__number{color:#fff;background:var(--ink);width:34px;height:34px;font-family:var(--font-display);border-radius:4px;place-items:center;font-size:11px;display:grid}.level-card.is-passed .level-card__number{background:var(--green)}.level-card__body{flex-direction:column;flex:1;min-width:0;margin:12px 0 10px;display:flex}.level-card__body small,.level-card__body span{color:var(--muted);font-size:9px}.level-card__body strong{-webkit-line-clamp:2;-webkit-box-orient:vertical;margin:6px 0;font-size:14px;line-height:1.3;display:-webkit-box;overflow:hidden}.level-card__action{color:#fff;background:var(--ink);cursor:pointer;border:0;border-radius:5px;width:100%;min-height:38px;padding:8px;font-size:10px;font-weight:850}.level-card__action--locked{color:#766f66;background:#e1dbd2;border:1px solid #c8beb0}.level-card__action:disabled{opacity:.55}.star-rating{color:#cfc6b7;letter-spacing:5px;margin:10px 0;font-size:30px;display:block}.star-rating .is-filled{color:#efa92d;text-shadow:0 2px #b97516}.star-rating--compact{letter-spacing:1px;white-space:nowrap;margin:0;font-size:12px}.game-heading{justify-content:space-between;align-items:end;gap:10px;margin:8px 2px 16px;display:flex}.game-heading span{color:var(--orange-dark);letter-spacing:1.5px;font-size:9px;font-weight:900}.game-heading h1{font-family:var(--font-display);margin:3px 0 0;font-size:25px;line-height:1.05}.game-heading>strong{color:var(--purple);white-space:nowrap;font-size:9px}.game-tools{grid-template-columns:1fr;margin-bottom:14px;display:grid}.game-tool{border:1px solid var(--line);background:var(--card);text-align:left;cursor:pointer;border-radius:7px;grid-template-columns:30px 1fr auto;align-items:center;gap:7px;min-width:0;min-height:58px;padding:9px 10px;display:grid}.game-tool>span{background:var(--paper-deep);border-radius:50%;place-items:center;width:28px;height:28px;font-size:13px;display:grid}.game-tool>div{flex-direction:column;min-width:0;display:flex}.game-tool strong{text-overflow:ellipsis;white-space:nowrap;font-size:10px;overflow:hidden}.game-tool small{color:var(--muted);text-overflow:ellipsis;white-space:nowrap;margin-top:2px;font-size:8px;overflow:hidden}.game-tool b{color:var(--orange)}.game-tool--rules{border-left:4px solid var(--orange)}.rule-card{border:1px solid #d3c4ae;border-top:4px solid var(--orange);background:#fffaf0;padding:16px;position:relative;box-shadow:4px 5px #dfd3c1}.rule-card:after{content:"内部";color:#c64a3d52;font-size:20px;font-weight:900;position:absolute;top:8px;right:10px;transform:rotate(-8deg)}.rule-card ol{gap:8px;margin:0;padding:0;list-style:none;display:grid}.rule-card li{grid-template-columns:22px 1fr;align-items:start;gap:8px;display:grid}.rule-card li>span{color:#fff;background:var(--ink);border-radius:50%;place-items:center;width:20px;height:20px;font-size:9px;font-weight:900;display:grid}.rule-card p{margin:1px 0 0;font-size:12px;font-weight:650;line-height:1.5}.scene-instruction{align-items:center;gap:10px;margin:20px 0 10px;display:flex}.scene-instruction>span{font-size:24px}.scene-instruction div{flex-direction:column;display:flex}.scene-instruction strong{font-size:13px}.scene-instruction small{color:var(--muted);font-size:10px}.scene-board{aspect-ratio:4/3;border:3px solid var(--ink);background:#e9dfcf;border-radius:8px;width:100%;position:relative;overflow:hidden;box-shadow:0 10px 22px #28221b26}.scene-board__image,.scene-board__fallback{width:100%;height:100%}.scene-board__image{object-fit:cover;display:block}.scene-board__fallback{text-align:center;background:linear-gradient(135deg,#6055a517 25%,#0000 25%) -12px 0/24px 24px,linear-gradient(225deg,#f26b3a1a 25%,#0000 25%) -12px 0/24px 24px,#f7f0e4;flex-direction:column;justify-content:center;align-items:center;padding:24px;display:flex}.scene-board__fallback span{font-size:54px}.scene-board__fallback strong{margin:10px 0 4px;font-size:16px}.scene-board__fallback small{color:var(--muted);font-size:11px}.scene-board__hotspots{position:absolute;inset:0}.scene-board__stamp{color:#fff;pointer-events:none;background:#20242dad;padding:3px 6px;font-size:8px;position:absolute;bottom:6px;right:7px}.hotspot{cursor:pointer;background:0 0;border:1px dashed #0000;border-radius:8px;padding:0;position:absolute}.hotspot__pulse{background:#f26b3aad;border:2px solid #ffffffe0;border-radius:50%;width:14px;height:14px;animation:1.8s infinite hotspot-pulse;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);box-shadow:0 0 0 4px #f26b3a2e}.hotspot.is-debug{background:#d12e6d1f;border-color:#d12e6d}.hotspot.is-highlighted{z-index:3;background:#ffe86d40;border:3px solid #ffe86d;box-shadow:0 0 0 5px #ffe86d47,0 0 24px #fff28a}.hotspot__label{color:#fff;background:var(--ink);white-space:nowrap;border-radius:3px;padding:3px 6px;font-size:9px;font-weight:800;position:absolute;bottom:calc(100% + 5px);left:50%;transform:translate(-50%)}@keyframes hotspot-pulse{0%,to{opacity:.72;transform:translate(-50%,-50%)scale(.85)}50%{opacity:1;transform:translate(-50%,-50%)scale(1.1)}}.hint-bar{border:1px solid var(--line);background:#fffdf8cc;grid-template-columns:1fr auto;align-items:center;gap:10px;margin-top:12px;padding:12px;display:grid}.hint-bar.is-active{background:#fff6d9;border-color:#d8a93c}.hint-bar>div{flex-direction:column;display:flex}.hint-bar strong{font-size:11px}.hint-bar span{color:var(--muted);margin-top:2px;font-size:9px;line-height:1.35}.hint-bar .button{min-height:42px;padding:8px 10px;font-size:10px}.debug-note{color:#a72b64;text-align:center;font-size:9px}.overlay{z-index:20;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);background:#17191e9e;width:min(430px,100vw);margin:0 auto;display:flex;position:fixed;inset:0}.overlay--sheet{align-items:end}.action-sheet{width:100%;max-height:82vh;padding:12px 18px max(20px, env(safe-area-inset-bottom));background:var(--card);border-radius:22px 22px 0 0;animation:.2s ease-out sheet-in;overflow-y:auto;box-shadow:0 -15px 40px #0003}.action-sheet__handle{background:var(--line);border-radius:4px;width:42px;height:4px;margin:0 auto 15px;display:block}.action-sheet__heading{justify-content:space-between;align-items:start;gap:10px;display:flex}.action-sheet__heading small{color:var(--orange-dark);letter-spacing:1px;font-size:9px;font-weight:900}.action-sheet h2{font-family:var(--font-display);margin:3px 0 0;font-size:22px}.action-sheet>p{color:var(--muted);margin:12px 0 16px;font-size:12px;line-height:1.6}.action-sheet__actions{gap:9px;display:grid}.action-sheet__actions button{border:1px solid var(--line);background:var(--paper);text-align:left;cursor:pointer;border-radius:10px;grid-template-columns:30px 1fr;align-items:center;gap:10px;min-height:52px;padding:10px;font-size:12px;font-weight:750;display:grid}.action-sheet__actions button:active{border-color:var(--orange);background:#fff4e9}.action-sheet__actions span{color:#fff;background:var(--ink);border-radius:50%;place-items:center;width:28px;height:28px;font-size:10px;display:grid}@keyframes sheet-in{0%{opacity:0;transform:translateY(30px)}}.overlay--modal{justify-content:center;align-items:center;padding:20px}.rule-modal{border:2px solid var(--ink);background:var(--card);border-radius:9px;width:100%;max-height:82vh;padding:18px;animation:.18s ease-out modal-in;overflow-y:auto;box-shadow:8px 9px #20242d52}.rule-modal__heading{justify-content:space-between;align-items:start;gap:12px;margin-bottom:14px;display:flex}.rule-modal__heading small{color:var(--orange-dark);letter-spacing:1.3px;font-size:9px;font-weight:900}.rule-modal__heading h2{font-family:var(--font-display);margin:4px 0 0;font-size:22px}.rule-modal .rule-card{margin-bottom:18px}.rule-modal>.button{width:100%}.unlock-modal{border:2px solid var(--ink);background:var(--card);text-align:center;border-radius:10px;width:100%;padding:26px 20px 18px;animation:.18s ease-out modal-in;position:relative;box-shadow:8px 9px #20242d52}.unlock-modal:before{content:"";background:var(--purple);height:6px;position:absolute;top:0;left:0;right:0}.unlock-modal__icon{background:var(--paper-deep);border-radius:50%;place-items:center;width:54px;height:54px;margin:0 auto 10px;font-size:25px;display:grid}.unlock-modal>small{color:var(--muted);letter-spacing:1px;font-size:9px;font-weight:900}.unlock-modal h2{font-family:var(--font-display);margin:5px 0 9px;font-size:22px}.unlock-modal>p{color:var(--muted);margin:0;font-size:12px;line-height:1.65}.unlock-modal__note{border-left:3px solid var(--purple);color:#554d89;text-align:left;background:#efedf8;margin:14px 0;padding:10px;font-size:10px;line-height:1.5}.unlock-modal__actions{gap:6px;display:grid}.result-modal{border:2px solid var(--ink);background:var(--card);text-align:center;border-radius:8px;width:100%;padding:26px 20px 18px;animation:.18s ease-out modal-in;position:relative;box-shadow:8px 9px #20242d52}.result-modal:before{content:"";background:var(--blue);height:7px;position:absolute;top:0;left:0;right:0}.result-modal--success:before{background:var(--green)}.result-modal--failed:before{background:var(--red)}.result-modal__icon{width:52px;height:52px;color:var(--blue);font-family:var(--font-display);border:3px solid;border-radius:50%;place-items:center;margin:0 auto 10px;font-size:27px;display:grid}.result-modal--success .result-modal__icon{color:var(--green)}.result-modal--failed .result-modal__icon{color:var(--red)}.result-modal>small{color:var(--muted);letter-spacing:1.5px;font-size:9px;font-weight:900}.result-modal h2{font-family:var(--font-display);margin:4px 0 8px;font-size:24px}.result-modal>p{color:var(--muted);margin:0 auto;font-size:12px;line-height:1.65}.result-modal__explanation{border-left:3px solid var(--green);text-align:left;background:#edf6ef;flex-direction:column;margin:12px 0;padding:12px;display:flex}.result-modal__explanation strong{color:var(--green);margin-bottom:3px;font-size:10px}.result-modal__explanation span{font-size:11px;line-height:1.55}.result-modal__actions{gap:8px;margin-top:16px;display:grid}@keyframes modal-in{0%{opacity:0;transform:scale(.95)translateY(8px)}}.toast{z-index:50;right:20px;bottom:max(24px, env(safe-area-inset-bottom));color:#fff;text-align:center;background:#20242df0;border:1px solid #4e5158;border-radius:8px;max-width:390px;min-height:44px;margin:0 auto;padding:12px 16px;font-size:12px;font-weight:700;position:fixed;left:20px;box-shadow:0 10px 24px #0003}.empty-state{flex-direction:column;justify-content:center;align-items:center;gap:20px;display:flex}@media (width<=360px){.page{padding-left:14px;padding-right:14px}.home-hero h1{font-size:43px}.template-card{grid-template-columns:46px 1fr 20px;gap:9px}.template-card__emoji{width:43px;height:43px}.hint-bar{grid-template-columns:1fr}}@media (prefers-reduced-motion:reduce){*,:before,:after{scroll-behavior:auto!important;transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}
