:root{font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;color:#342f2a;background:#ede4d6}*{box-sizing:border-box}body{margin:0;min-height:100vh;background:linear-gradient(90deg,rgba(72,64,55,.08) 1px,transparent 1px),linear-gradient(180deg,#f2eadf,#ded3c2);background-size:28px 28px,100% 100%}button{border:0;font:inherit;cursor:pointer}#app{min-height:100vh;display:grid;grid-template-columns:minmax(210px,280px) minmax(390px,520px);gap:22px;justify-content:center;align-items:start;padding:22px}.app-view--levels{grid-template-columns:minmax(320px,520px)}.app-view--game{grid-template-columns:520px}.app-view--levels .game-shell,.app-view--game .level-panel{display:none}.level-panel,.game-shell{border:1px solid rgba(78,70,62,.24);background:#fffbf3e6;box-shadow:0 14px 40px #3e322621}.level-panel{border-radius:8px;padding:16px;max-height:calc(100vh - 44px);overflow:auto}.brand{display:grid;gap:2px;margin-bottom:14px}.brand span{font-size:12px;text-transform:uppercase;letter-spacing:0;color:#776c60}.brand strong{font-size:24px}.level-cards{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.level-card{min-height:82px;display:grid;grid-template-rows:auto 1fr auto;gap:4px;padding:10px;border-radius:8px;color:#342f2a;background:#f6efe4;border:1px solid #d0c4b4;text-align:left}.level-card span{width:24px;height:24px;display:grid;place-items:center;border-radius:50%;background:#4f473e;color:#fff7e9;font-size:12px;font-weight:800}.level-card strong{font-size:13px;line-height:1.15}.level-card em{min-height:16px;color:#c18c25;font-style:normal}.level-card.is-active{border-color:#4f473e;background:#fff7e9;box-shadow:inset 0 0 0 2px #4f473e1f}.level-card.is-locked{color:#958a7c;background:#e5ddd1;cursor:default}.game-shell{width:520px;border-radius:8px;overflow:hidden}.top-bar{display:grid;grid-template-columns:1fr auto auto auto;align-items:center;gap:12px;padding:14px;background:#4f473e;color:#fff7e9}.top-bar>div:first-child{display:grid;gap:2px}.top-bar span{font-size:12px;color:#d9ccbd}.top-bar strong{font-size:18px}.top-bar button,.result-actions button{min-height:36px;padding:0 14px;border-radius:8px;background:#e3b341;color:#2f2b26;font-weight:800}.meter-row{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:8px}.meter-row span{padding:5px 8px;border-radius:8px;background:#ffffff1f;color:#fff7e9}.stars span{color:#fff7e94d}.stars span.is-filled{color:#e3b341}.objective-panel{display:grid;grid-template-columns:1fr auto;gap:12px;align-items:start;padding:12px 14px;border-bottom:1px solid #ddd1c2}.score-lane{grid-column:1 / -1;position:relative;height:34px;border-radius:999px;background:#d8cdbc;box-shadow:inset 0 1px 2px #463c3229}.score-lane>span{position:absolute;inset:0 auto 0 0;width:0%;border-radius:inherit;background:linear-gradient(90deg,#d84d4d,#e3b341,#53a968);transition:width .22s ease}.score-lane__value{position:absolute;left:14px;top:50%;transform:translateY(-50%);z-index:2;font-size:13px;color:#342f2a;text-shadow:0 1px 0 rgba(255,250,243,.65)}.score-star{position:absolute;top:50%;left:var(--star-pos, 50%);transform:translate(-50%,-50%);min-width:42px;display:grid;place-items:center;gap:0;color:#85786a;font-style:normal;text-align:center}.score-star--one{--star-pos: var(--one-star)}.score-star--two{--star-pos: var(--two-star)}.score-star--three{--star-pos: calc(var(--three-star) - 22px)}.score-star b{width:28px;height:28px;display:grid;place-items:center;border-radius:50%;background:#fffaf3;border:2px solid #bdae9d;color:#bdae9d;font-size:12px}.score-star em{display:none}.score-star.is-reached b{border-color:#4f473e;background:#4f473e;color:#e3b341}.objective-list{grid-column:1;display:grid;gap:8px}.objective-row{display:grid;grid-template-columns:18px minmax(52px,1fr) auto;gap:8px;align-items:center;font-size:13px}.objective-row strong{font-size:12px}.objective-icon{width:18px;height:18px;border-radius:4px;border:1px solid rgba(52,47,42,.18)}.objective-icon--score{background:#4f473e}.objective-icon--blocker{background:#77716a}.objective-icon--glass{position:relative;overflow:hidden;background:#9fe8ff7a;border-color:#4aa8ffa6;box-shadow:inset 0 0 0 2px #ffffffb8}.objective-icon--glass:before{content:"";position:absolute;left:3px;top:4px;width:11px;height:3px;border-radius:999px;background:#ffffffd9;transform:rotate(-18deg)}.shot-chip{min-width:92px;display:grid;place-items:center;gap:3px;padding:10px;border-radius:8px;background:#efe2cf;font-size:12px;color:#6c6054}.shot-chip strong{max-width:92px;font-size:13px;color:#342f2a;line-height:1.15;text-align:center}.canvas-wrap{display:grid;place-items:center;padding:10px 0 8px}#game{width:390px;height:640px}#game canvas{width:390px!important;height:640px!important;display:block}.status-bar{min-height:48px;display:flex;align-items:center;padding:12px 14px;border-top:1px solid #ddd1c2;background:#fffaf3;color:#4f473e;font-weight:700}.result-modal{position:fixed;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;padding:20px;background:#2b241d7a;z-index:5}.result-modal.is-hidden{display:none}.result-card{width:min(340px,100%);display:grid;gap:12px;padding:20px;border-radius:8px;background:#fffaf3;border:1px solid #d0c4b4;box-shadow:0 18px 60px #00000038}.result-card span{font-size:12px;color:#776c60;text-transform:uppercase}.result-card h2,.result-card p{margin:0}.result-actions{display:flex;gap:8px}.result-actions button:disabled{opacity:.45;cursor:default}.fly-token{position:fixed;z-index:9999;width:18px;height:18px;border-radius:5px;pointer-events:none;background:#e3b341;box-shadow:0 5px 16px #342f2a3d,inset 0 0 0 2px #ffffff8c}.fly-token--score{border-radius:999px;background:#ffd45f}@media (max-width: 760px){#app{display:block;padding:0}.level-panel{position:static;max-height:none;border-radius:0;border-width:0 0 1px}.level-cards{display:flex;overflow-x:auto;padding-bottom:4px}.level-card{min-width:120px}.game-shell{width:100%;border-radius:0;border-width:0}.top-bar{grid-template-columns:1fr auto}.meter-row{grid-column:1 / -1;justify-content:flex-start}}
