*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body{width:100%;height:100%;overflow:hidden;font-family:Outfit,-apple-system,BlinkMacSystemFont,sans-serif;color:#2e3a4d;background:linear-gradient(180deg,#ebe2cc,#d9cdb1);-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none;touch-action:manipulation}#app{width:100%;height:100%;height:100dvh;position:relative;max-width:540px;margin:0 auto;overflow:hidden}.screen{position:absolute;top:0;right:0;bottom:0;left:0;display:none;flex-direction:column;padding:env(safe-area-inset-top) env(safe-area-inset-right) env(safe-area-inset-bottom) env(safe-area-inset-left)}.screen.active{display:flex}h1,h2,h3{font-family:Fraunces,serif;font-weight:700;letter-spacing:-.02em}h1{font-size:56px;line-height:1;font-variation-settings:"opsz" 144}h2{font-size:32px;line-height:1.1;font-variation-settings:"opsz" 60}h3{font-size:22px;line-height:1.2;font-variation-settings:"opsz" 36}button{font-family:inherit;font-size:16px;font-weight:500;border:none;cursor:pointer;color:inherit;background:transparent;-webkit-tap-highlight-color:transparent;transition:transform .08s ease,opacity .15s ease}button:active{transform:scale(.96)}.btn-primary{background:#2e3a4d;color:#faf6ec;padding:14px 32px;border-radius:999px;font-size:17px;font-weight:600;min-height:48px;min-width:140px;box-shadow:0 2px #00000026,0 6px 18px #2e3a4d2e}.btn-secondary{background:#2e3a4d14;color:#2e3a4d;padding:12px 24px;border-radius:999px;font-size:15px;font-weight:500;min-height:44px}.btn-icon{width:44px;height:44px;border-radius:50%;background:#ffffffb3;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px #2e3a4d1f;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.btn-icon svg{width:22px;height:22px;stroke:#2e3a4d;fill:none;stroke-width:2.2;stroke-linecap:round;stroke-linejoin:round}#splash{justify-content:center;align-items:center;gap:12px;padding:32px}#splash .logo{width:120px;height:120px;background:#faf6ec;border-radius:22px;display:flex;align-items:center;justify-content:center;box-shadow:0 8px 30px #2e3a4d26,0 2px #00000014;margin-bottom:18px;transform:rotate(-8deg)}#splash .logo .pip{width:16px;height:16px;background:#1a1a1a;border-radius:50%;box-shadow:-28px -28px #1a1a1a,28px -28px #1a1a1a,-28px 28px #1a1a1a,28px 28px #1a1a1a,-28px 0 #1a1a1a,28px 0 #1a1a1a}#splash h1{color:#2e3a4d}#splash .tag{font-size:16px;opacity:.65;margin-bottom:30px;text-align:center;max-width:280px}#menu{justify-content:center;align-items:center;gap:14px;padding:32px}#menu h1{margin-bottom:8px;color:#2e3a4d}#menu .menu-tag{opacity:.6;font-size:14px;margin-bottom:28px}#menu .menu-buttons{display:flex;flex-direction:column;gap:12px;width:100%;max-width:280px}#levels{padding:18px}#levels .ls-header{display:flex;align-items:center;gap:12px;margin-bottom:18px;padding-top:4px}#levels .ls-header .title{flex:1}#levels .ls-header h2{font-size:26px}#levels .ls-header .progress-text{font-size:13px;opacity:.6;margin-top:2px}#levels .ls-content{flex:1;overflow-y:auto;padding-bottom:24px}#levels .levels-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:8px;padding-bottom:24px}#levels .levels-grid .level-card{aspect-ratio:1}.level-card{background:#ffffff8c;border-radius:14px;padding:14px 10px 12px;text-align:center;cursor:pointer;position:relative;aspect-ratio:1;display:flex;flex-direction:column;align-items:center;justify-content:center;box-shadow:0 2px 6px #2e3a4d0f;transition:transform .1s ease,box-shadow .15s ease}.level-card:active{transform:scale(.97)}.level-card.locked{opacity:.45;cursor:not-allowed;background:#2e3a4d0f}.level-card.locked:active{transform:scale(1)}.level-card .num{font-family:Fraunces,serif;font-size:22px;font-weight:700;color:#2e3a4d;line-height:1}.level-card .name{display:none}.level-card .star{position:absolute;top:4px;right:5px;color:#f5c518;font-size:11px}.level-card .check{position:absolute;top:4px;right:5px;width:13px;height:13px;border-radius:50%;background:#5c8a4a;color:#fff;font-size:9px;display:flex;align-items:center;justify-content:center}#play{padding:0;background:linear-gradient(180deg,#ebe2cc,#d9cdb1)}#play .play-top{display:flex;align-items:center;padding:14px 16px 8px;padding-top:max(14px,env(safe-area-inset-top));gap:10px;z-index:5}#play .play-info{flex:1;text-align:center}#play .level-title{font-family:Fraunces,serif;font-size:18px;font-weight:700;line-height:1.1;color:#2e3a4d}#play .level-stats{font-size:12px;opacity:.65;margin-top:2px}#canvas-container{flex:1;position:relative;overflow:hidden;min-height:0}#canvas-container canvas{display:block;touch-action:none}#intro-banner{position:absolute;top:12px;left:50%;transform:translate(-50%);background:#2e3a4deb;color:#faf6ec;padding:12px 18px;border-radius:14px;max-width:84%;text-align:center;font-size:14px;line-height:1.35;z-index:10;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);box-shadow:0 6px 24px #0000002e;animation:bannerIn .35s ease-out;cursor:pointer}@keyframes bannerIn{0%{transform:translate(-50%,-10px);opacity:0}to{transform:translate(-50%);opacity:1}}#stuck-toast{position:absolute;bottom:110px;left:50%;transform:translate(-50%);background:#2e3a4deb;color:#faf6ec;padding:10px 16px;border-radius:999px;font-size:13px;z-index:10;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);pointer-events:none;opacity:0;transition:opacity .2s ease}#stuck-toast.visible{opacity:1}.play-controls{padding:8px 16px 16px;padding-bottom:max(16px,env(safe-area-inset-bottom));display:flex;align-items:center;justify-content:center;gap:12px;min-height:80px}.dpad{display:grid;grid-template-columns:repeat(3,44px);grid-template-rows:repeat(3,44px);gap:4px}.dpad button{background:#ffffff80;border-radius:10px;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 4px #0000000f}.dpad button:disabled{opacity:.3}.dpad svg{width:20px;height:20px;stroke:#2e3a4d;fill:none;stroke-width:2.5;stroke-linecap:round;stroke-linejoin:round}.dpad-up{grid-column:2;grid-row:1}.dpad-left{grid-column:1;grid-row:2}.dpad-right{grid-column:3;grid-row:2}.dpad-down{grid-column:2;grid-row:3}#win{justify-content:center;align-items:center;padding:32px;gap:14px;background:#ebe2cce6;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px)}#win .star-row{font-size:48px;color:#f5c518;margin-bottom:8px;letter-spacing:4px}#win h2{color:#2e3a4d}#win .stats{background:#ffffff80;border-radius:16px;padding:18px 28px;margin:14px 0 22px;display:flex;gap:32px}#win .stat{text-align:center}#win .stat .label{font-size:12px;opacity:.6;text-transform:uppercase;letter-spacing:.08em}#win .stat .value{font-family:Fraunces,serif;font-size:28px;font-weight:700;line-height:1;margin-top:4px}#win .win-buttons{display:flex;gap:10px;flex-wrap:wrap;justify-content:center}#win-gate{font-size:14px;color:#2e3a4d;opacity:.85;text-align:center;margin:0 0 18px;padding:0 24px;line-height:1.4}#win-gate.locked{color:#b8554a;opacity:1;font-weight:600}#settings,#about{padding:18px}.panel-header{display:flex;align-items:center;gap:12px;margin-bottom:22px;padding-top:4px}.panel-header h2{flex:1;font-size:26px}.panel-content{flex:1;overflow-y:auto;padding-bottom:30px}.setting-row{display:flex;align-items:center;justify-content:space-between;padding:14px 4px;border-bottom:1px solid rgba(46,58,77,.08)}.setting-row .label{font-size:16px}.setting-row .desc{font-size:12px;opacity:.55;margin-top:2px}.setting-row .label-block{flex:1;padding-right:12px}.toggle{position:relative;width:50px;height:30px;background:#2e3a4d2e;border-radius:999px;cursor:pointer;transition:background .18s ease;flex-shrink:0}.toggle:after{content:"";position:absolute;top:3px;left:3px;width:24px;height:24px;background:#faf6ec;border-radius:50%;transition:transform .18s ease;box-shadow:0 1px 3px #00000026}.toggle.on{background:#5c8a4a}.toggle.on:after{transform:translate(20px)}#about p{line-height:1.55;margin-bottom:14px;opacity:.85;font-size:14px}#about .credit{font-size:12px;opacity:.55;margin-top:18px}#about h3{margin-top:18px;margin-bottom:8px}.reset-btn{margin-top:18px;background:#d245451a;color:#d24545;padding:12px 20px;border-radius:12px;width:100%;font-weight:500}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;transition-duration:.01ms!important}}
