*{box-sizing:border-box}body,html{width:100%;height:100%;margin:0;overflow:hidden;background:#000}body{font-family:Arial,Helvetica,sans-serif}a{color:inherit;text-decoration:none}.bloom-page{position:relative;display:grid;place-items:center;width:100vw;height:100vh;overflow:hidden;-webkit-user-select:none;-moz-user-select:none;user-select:none;cursor:none;background:#000}.bloom-stage{position:relative;width:min(100vw,75vh);height:min(100vh,133.333vw);aspect-ratio:3/4;overflow:hidden;background:linear-gradient(180deg,#000 0,#050613 18%,#252862 60%,#777cff)}.cursor-dot{top:0;left:0;z-index:3;width:43px;height:46px;margin:-5px 0 0 -5px;background:url(/finger-cursor.png) 50%/contain no-repeat;opacity:0;will-change:transform;transition:opacity .18s ease}.bloom-stage:after,.cursor-dot{position:absolute;pointer-events:none}.bloom-stage:after{content:"";inset:0;z-index:1;background:linear-gradient(180deg,rgba(0,0,0,.14),rgba(0,0,0,0) 52%)}.bloom-canvas{position:absolute;inset:0;width:100%;height:100%;display:block}.webgpu-warning{position:absolute;inset:0;z-index:3;display:grid;place-items:center;padding:24px;color:#eee8ff;font-size:13px;text-align:center;background:linear-gradient(180deg,#000 0,#252862 58%,#8386ff)}.control-panel{position:absolute;top:0;left:0;z-index:4;width:240px;padding:12px;border:1px solid rgba(238,232,255,.14);background:rgba(8,9,24,.42);color:#eee8ff;font-size:11px;line-height:1.2;opacity:.48;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);box-shadow:0 16px 50px rgba(0,0,0,.18);transition:opacity .16s ease,background .16s ease}.control-panel:focus-within,.control-panel:hover{opacity:1;background:rgba(8,9,24,.68)}.control-panel__header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin:-4px -4px 10px;padding:4px;cursor:-webkit-grab;cursor:grab;text-transform:uppercase}.control-panel__header:active{cursor:-webkit-grabbing;cursor:grabbing}.control-panel__header button{border:1px solid rgba(238,232,255,.24);background:rgba(238,232,255,.08);color:#eee8ff;padding:4px 7px;font:inherit;cursor:pointer}.control-row{display:block;padding:7px 0}.control-row>span{display:flex;justify-content:space-between;gap:12px;margin-bottom:6px;color:rgba(238,232,255,.82)}.control-row input{width:100%;accent-color:#c6c8ff}@media (max-width:640px){.control-panel{width:min(240px,calc(100vw - 20px))}}