*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body{height:100%;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:14px;color:#333;background:#e8e8e4}#app{display:flex;height:100%}#viewport{flex:1 1 65%;min-width:0;position:relative;background:#f5f5f0}#viewport canvas{display:block;width:100%!important;height:100%!important}#controls{flex:0 0 320px;padding:20px;overflow-y:auto;background:#fff;border-left:1px solid #ddd}#controls h2{font-size:18px;margin-bottom:16px;color:#222}#controls label{display:block;margin-bottom:12px;font-weight:500}#controls select,#controls input[type=number]{display:block;width:100%;margin-top:4px;padding:6px 8px;border:1px solid #ccc;border-radius:4px;font-size:14px}#controls input[type=range]{display:block;width:100%;margin-top:4px}.category-tabs{display:flex;gap:4px;margin-bottom:12px;overflow-x:auto;border-bottom:1px solid #ddd}.category-tab{flex:0 0 auto;padding:6px 12px;border:none;background:transparent;cursor:pointer;font-size:13px;color:#777;border-bottom:2px solid transparent;margin-bottom:-1px;white-space:nowrap;transition:color .15s,border-color .15s}.category-tab:hover{color:#333}.category-tab.active{color:#222;border-bottom-color:#2e8bd9;font-weight:600}.shape-info{margin-top:-8px;margin-bottom:12px;font-size:12px;color:#888}.checkboxes{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:16px}.checkboxes label{display:flex;align-items:center;gap:4px;font-weight:400;margin-bottom:0}.buttons{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:16px}.buttons button{padding:8px 12px;border:1px solid #bbb;border-radius:4px;background:#f0f0f0;cursor:pointer;font-size:13px;transition:background .15s}.buttons button:hover{background:#e0e0e0}.buttons button:disabled{opacity:.55;cursor:progress}.toast{position:fixed;bottom:24px;left:50%;transform:translate(-50%);padding:8px 14px;background:#141414d9;color:#fff;font-size:13px;border-radius:4px;pointer-events:none;opacity:0;transition:opacity .2s;z-index:1000}.toast.show{opacity:1}.metrics{padding:12px;background:#f8f8f8;border-radius:4px;border:1px solid #eee;font-size:13px;line-height:1.6}.metrics div{display:flex;justify-content:space-between}.nav-links{display:flex;gap:16px;margin-top:16px}.github-link{display:inline-flex;align-items:center;gap:6px;color:#555;font-size:13px;text-decoration:none;transition:color .15s}.github-link:hover{color:#111}@media(max-width:768px){#app{flex-direction:column}#viewport{flex:0 0 50vh}#controls{flex:1;border-left:none;border-top:1px solid #ddd}}
