@import"https://fonts.googleapis.com/css2?family=Merriweather:ital,wght@0,300;0,400;0,700;0,900;1,300;1,400;1,700;1,900&display=swap";*,*:before,*:after{box-sizing:border-box}html,body{margin:0!important;padding:0!important;height:100%!important;width:100%!important;display:flex!important;flex-direction:column!important;justify-content:center!important;align-items:center!important;overflow:hidden!important;background:#0d0617!important;font-family:Merriweather,serif}@media(max-width:1000px){html,body{height:auto!important;display:block!important;overflow:auto!important}}.app-layout{display:grid;grid-template-areas:". top ." "left center right" ". bottom .";grid-template-columns:auto 1fr auto;grid-template-rows:auto 1fr auto;width:100%!important;height:100%!important;box-sizing:border-box;padding:16px;gap:16px}.dock{background:#0f0f1ee6;border:1px solid rgba(180,150,255,.3);border-radius:16px;padding:12px;box-shadow:0 8px 24px #00000080;display:flex;align-items:center;gap:12px}.dock-top{grid-area:top;justify-content:center;justify-self:stretch;align-self:end}.dock-bottom{grid-area:bottom;justify-content:center;justify-self:stretch;align-self:start}.dock-left{grid-area:left;flex-direction:column;justify-content:center;justify-self:end;align-self:stretch}.dock-right{grid-area:right;flex-direction:column;justify-content:center;justify-self:start;align-self:stretch}.dock-left{min-width:220px}.workspace{grid-area:center;display:flex;justify-content:center;align-items:center;overflow:hidden;min-width:0;min-height:0}@media(max-width:1000px){.app-layout{grid-template-areas:"top" "left" "center" "right" "bottom";grid-template-columns:1fr;grid-template-rows:auto auto auto auto auto;width:100vw;height:auto!important;overflow-y:visible!important;padding:10px;gap:12px;justify-content:center;align-content:start}.workspace{min-height:auto;overflow:visible}.dock-left,.dock-right,.dock-top,.dock-bottom{align-self:center;justify-self:stretch}.dock-left,.dock-right{flex-direction:row;flex-wrap:wrap}.dock-left{min-width:0}.dock{flex-wrap:wrap}.divider-h{display:none}.control-group.vert{flex-direction:row}}.control-group{display:flex;align-items:center;gap:8px;color:#fff}.control-group.vert{flex-direction:column}label{font-size:.85rem;font-weight:800;color:#ffffffe6;letter-spacing:.5px;text-transform:uppercase}input[type=color]{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:none;width:32px;height:32px;border-radius:50%;cursor:pointer;padding:0;background:transparent;overflow:hidden;outline:none}input[type=color]::-webkit-color-swatch-wrapper{padding:0}input[type=color]::-webkit-color-swatch{border:none;border-radius:50%}input[type=color]::-moz-color-swatch{border:none;border-radius:50%}input[type=range]{accent-color:#b496ff;cursor:pointer;width:100px}button{background:#b496ff26;border:1px solid rgba(180,150,255,.5);color:#fff;padding:8px 16px;border-radius:8px;cursor:pointer;font-weight:600;font-size:.85rem;transition:background .15s ease,transform .1s ease,box-shadow .15s ease}button:hover{background:#b496ff59;transform:translateY(-1px);box-shadow:0 4px 12px #b496ff33}button:active{transform:translateY(1px)}button.active{background:#b496ff80;border-color:#d4bbff;box-shadow:0 0 15px #b496ff99,inset 0 0 10px #0000004d;text-shadow:0 0 5px rgba(255,255,255,.8)}.dock-left button,.dock-right button{width:100%}.primary-btn{background:linear-gradient(135deg,#b496ff8c,#ff96e673);border-color:#e4c9ff;font-weight:700;text-transform:uppercase;letter-spacing:.7px}.primary-btn:hover{background:linear-gradient(135deg,#b496ffbf,#ff96e699)}.mode-btn{padding:6px 12px;font-size:.8rem}.tool-set{display:flex;flex-direction:column;gap:10px;align-items:stretch;width:100%}.tool-set[hidden]{display:none}.slider-row{display:grid;grid-template-columns:1fr auto;grid-template-rows:auto auto;align-items:center;gap:2px 8px}.slider-row>label{grid-column:1 / -1;grid-row:1;font-size:.72rem;letter-spacing:.5px;opacity:.85}.slider-row>input[type=range]{grid-column:1;grid-row:2;width:100%;min-width:0}.slider-row>.slider-value{grid-column:2;grid-row:2;min-width:2ch;color:#e4c9ff;font-variant-numeric:tabular-nums;font-weight:700;font-size:.8rem;text-align:right}@media(max-width:1000px){.tool-set{flex-direction:row;flex-wrap:wrap;align-items:center}.slider-row{flex:1 1 140px}}.divider{width:2px;height:24px;background:#fff3;border-radius:2px}.divider-h{height:2px;width:24px;background:#fff3;border-radius:2px;align-self:center}#cursor-ring{position:fixed;pointer-events:none;transform:translate(-50%,-50%);z-index:9999;display:none}#p5-container{aspect-ratio:1 / 1;height:100svh;max-height:calc(100svh - 220px);max-width:calc(100vw - 360px);width:auto;box-sizing:border-box;position:relative;border-radius:20px;box-shadow:0 0 40px #b496ff26,0 0 100px #000c;border:1px solid rgba(180,150,255,.2);overflow:hidden;background:#0d0617;margin:0;touch-action:none}@media(max-width:1000px){#p5-container{width:calc(100vw - 40px);height:calc(100vw - 40px);max-width:none;max-height:none}}#p5-container canvas{width:100%!important;height:100%!important;display:block!important}#p5-container canvas.three-d-canvas{position:absolute!important;top:0;right:0;bottom:0;left:0;z-index:2}
