*,:before,:after{box-sizing:border-box;margin:0;padding:0}[hidden]{display:none!important}:root{--bg:#0f0f0f;--surface:#181818;--border:#2a2a2a;--border-accent:#3d3d3d;--label:#555;--text-dim:#666;--text:#999;--text-bright:#ccc;--accent:#e0e0e0;--sidebar-width:350px}html,body{height:100%}body{background:var(--bg);color:var(--text);font-family:IBM Plex Mono,monospace;overflow:hidden}.app{height:100vh;display:flex;overflow:hidden}.sidebar{width:var(--sidebar-width);min-width:var(--sidebar-width);border-right:1px solid var(--border);background:var(--surface);flex-direction:column;height:100%;display:flex;overflow-y:auto}.sidebar-section{border-bottom:1px solid var(--border)}.sidebar-section summary.section-label{letter-spacing:.18em;text-transform:uppercase;color:var(--label);cursor:pointer;-webkit-user-select:none;user-select:none;justify-content:space-between;align-items:center;padding:12px 16px;font-size:9px;list-style:none;display:flex}.sidebar-section summary.section-label::-webkit-details-marker{display:none}.sidebar-section summary.section-label:after{content:"+";color:var(--text-dim);font-size:12px}.sidebar-section[open] summary.section-label:after{content:"−"}.sidebar-section--actions{border-bottom:none;border-top:1px solid var(--border);flex-direction:column;gap:8px;margin-top:auto;padding:14px 16px;display:flex}.section-content{padding:10px 16px 14px}.control-label{color:var(--label);letter-spacing:.1em;text-transform:uppercase;margin-top:10px;margin-bottom:6px;font-size:9px}.control-label:first-child{margin-top:0}input[type=number],input[type=text],select{background:var(--bg);border:1px solid var(--border-accent);color:var(--text-bright);padding:3px 5px;font-family:IBM Plex Mono,monospace;font-size:10px}input[type=range]{accent-color:var(--accent);cursor:pointer}input:disabled,select:disabled{opacity:.3;cursor:not-allowed}select{appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='8' height='5'%3E%3Cpath d='M0 0l4 5 4-5z' fill='%23666'/%3E%3C/svg%3E");background-position:right 6px center;background-repeat:no-repeat;padding-right:20px}.btn-primary,.btn-secondary{letter-spacing:.1em;text-transform:uppercase;cursor:pointer;border:1px solid var(--border-accent);width:100%;padding:10px 12px;font-family:IBM Plex Mono,monospace;font-size:11px}.btn-primary{background:var(--accent);color:#0f0f0f;border-color:var(--accent)}.btn-primary:hover{background:#fff;border-color:#fff}.btn-secondary{color:var(--text);background:0 0}.btn-secondary:hover{color:var(--text-bright);border-color:var(--text-dim)}.canvas-area{background:var(--bg);flex:1;justify-content:center;align-items:center;padding:32px;display:flex;overflow:hidden}.canvas-frame{justify-content:center;align-items:center;width:100%;height:100%;display:flex}#canvas-svg{aspect-ratio:1;background:#fff;max-width:100%;max-height:100%;display:block}.numeric-input{align-items:center;gap:6px;margin-bottom:6px;display:flex}.numeric-input__label{color:var(--text-dim);letter-spacing:.04em;flex-shrink:0;width:68px;font-size:9px}.numeric-input__range{flex:1}.numeric-input__number{text-align:right;flex-shrink:0;width:46px}.ar-row{gap:10px;margin-bottom:8px;display:flex}.ar-input-wrap{color:var(--text-dim);align-items:center;gap:5px;font-size:9px;display:flex}.ar-input{width:52px}.presets-row{flex-wrap:wrap;gap:4px;margin-bottom:10px;display:flex}.preset-btn{background:var(--border);border:1px solid var(--border-accent);color:var(--text);cursor:pointer;letter-spacing:.05em;padding:3px 8px;font-family:IBM Plex Mono,monospace;font-size:9px}.preset-btn:hover{color:var(--text-bright);border-color:var(--text-dim)}.checkbox-row{color:var(--text);cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:6px;margin-top:4px;font-size:10px;display:flex}.module-list{flex-direction:column;gap:6px;margin-bottom:8px;display:flex}.module-item{border:1px solid var(--border);background:#141414;align-items:flex-start;gap:6px;padding:8px;display:flex}.module-preview{border:1px solid var(--border-accent);background:#1a1a1a;flex-shrink:0;width:36px;height:36px;overflow:hidden}.module-controls{flex-direction:column;flex:1;gap:5px;min-width:0;display:flex}.shape-row{position:relative}.shape-picker-btn{background:var(--border);border:1px solid var(--border-accent);width:100%;color:var(--text);text-align:left;cursor:pointer;letter-spacing:.04em;padding:3px 7px;font-family:IBM Plex Mono,monospace;font-size:9px}.shape-picker-btn:hover{color:var(--text-bright)}.shape-dropdown{z-index:200;background:var(--surface);border:1px solid var(--border-accent);flex-direction:column;min-width:140px;display:flex;position:absolute;top:100%;left:0;box-shadow:0 4px 12px #00000080}.shape-option{border:none;border-bottom:1px solid var(--border);color:var(--text);cursor:pointer;text-align:left;background:0 0;align-items:center;gap:8px;width:100%;padding:5px 8px;font-family:IBM Plex Mono,monospace;font-size:9px;display:flex}.shape-option:last-child{border-bottom:none}.shape-option:hover{background:var(--border);color:var(--text-bright)}.shape-option.is-active{color:var(--accent)}.color-row{flex-wrap:wrap;align-items:center;gap:5px;display:flex}.color-label{color:var(--label);letter-spacing:.06em;text-transform:uppercase;cursor:default;align-items:center;gap:2px;font-size:8px;display:flex}input[type=color]{border:1px solid var(--border-accent);cursor:pointer;background:0 0;flex-shrink:0;width:20px;height:14px;padding:0}input[type=color].is-null{opacity:.25}.null-btn{border:1px solid var(--border);color:var(--text-dim);cursor:pointer;background:0 0;padding:0 3px;font-family:IBM Plex Mono,monospace;font-size:9px;line-height:14px}.null-btn:hover{color:var(--text-bright);border-color:var(--text-dim)}.stroke-weight-input{width:38px}.weight-row{align-items:center;gap:5px;display:flex}.weight-label{color:var(--label);letter-spacing:.06em;text-transform:uppercase;flex-shrink:0;width:40px;font-size:8px}.weight-row input[type=range]{flex:1}.weight-num-input{width:32px}.remove-btn{border:1px solid var(--border);color:var(--text-dim);cursor:pointer;background:0 0;flex-shrink:0;justify-content:center;align-items:center;width:18px;height:18px;margin-top:1px;padding:0;font-size:12px;line-height:1;display:flex}.remove-btn:hover:not(:disabled){color:var(--text-bright);border-color:var(--text-dim)}.remove-btn:disabled{opacity:.2;cursor:not-allowed}.add-module-btn{border:1px dashed var(--border-accent);width:100%;color:var(--text-dim);letter-spacing:.12em;text-transform:uppercase;cursor:pointer;background:0 0;padding:7px;font-family:IBM Plex Mono,monospace;font-size:9px}.add-module-btn:hover{color:var(--text-bright);border-color:var(--text-dim)}.axis-block{margin-bottom:14px}.axis-block:last-child{margin-bottom:0}.axis-title{color:var(--text-dim);letter-spacing:.08em;text-transform:uppercase;margin-bottom:8px;font-size:9px}.select-row{align-items:center;gap:6px;margin-bottom:6px;display:flex}.select-label{color:var(--text-dim);letter-spacing:.04em;flex-shrink:0;width:68px;font-size:9px}.select-row select{flex:1}.dist-toggle-btn{background:var(--border);border:1px solid var(--border-accent);color:var(--text);cursor:pointer;letter-spacing:.05em;text-align:left;flex:1;padding:3px 8px;font-family:IBM Plex Mono,monospace;font-size:9px}.dist-toggle-btn:hover{color:var(--text-bright);border-color:var(--text-dim)}.dist-toggle-btn.is-active{color:var(--accent);border-color:var(--border-accent)}.waveform-strip{align-items:stretch;gap:1px;height:16px;margin-top:8px;display:flex}.waveform-bar{background:var(--border-accent);flex-shrink:0;min-width:1px}.generation-section{flex-direction:column;gap:2px;display:flex}.grammar-toggle-row{justify-content:space-between;align-items:center;gap:8px;margin-top:4px;display:flex}.edit-grammar-btn{border:1px solid var(--border-accent);color:var(--text-dim);cursor:pointer;letter-spacing:.04em;white-space:nowrap;background:0 0;padding:3px 7px;font-family:IBM Plex Mono,monospace;font-size:9px}.edit-grammar-btn:hover{color:var(--text-bright);border-color:var(--text-dim)}.grammar-panel{overflow-x:auto}.grammar-shortcuts{gap:4px;margin-bottom:8px;display:flex}.grammar-shortcuts button{background:var(--border);border:1px solid var(--border-accent);color:var(--text-dim);cursor:pointer;letter-spacing:.04em;padding:3px 7px;font-family:IBM Plex Mono,monospace;font-size:9px}.grammar-shortcuts button:hover{color:var(--text-bright)}.grammar-table{border-collapse:collapse;table-layout:fixed}.grammar-th{width:28px;height:28px;padding:2px;overflow:hidden}.grammar-th svg{display:block}.grammar-table td{padding:2px}.grammar-cell-btn{border:1px solid var(--border-accent);background:var(--border);cursor:pointer;width:20px;height:20px;padding:0;display:block}.grammar-cell-btn:hover{border-color:var(--text-dim)}.grammar-cell-btn.is-active{background:var(--accent)}.shape-lib-divider{border-top:1px solid var(--border);margin:10px 0 12px}.shape-lib-section-label{color:var(--label);letter-spacing:.14em;text-transform:uppercase;margin-bottom:6px;font-size:8px}.shape-lib-builtin-grid{flex-wrap:wrap;gap:4px;margin-bottom:10px;display:flex}.shape-lib-item{color:var(--text);align-items:center;gap:6px;font-size:9px;display:flex}.shape-lib-item--builtin{border:1px solid var(--border);background:#141414;padding:4px 6px}.shape-lib-thumb{border:1px solid var(--border-accent);background:#1a1a1a;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;display:flex;overflow:hidden}.shape-lib-name{color:var(--text);letter-spacing:.02em;text-overflow:ellipsis;white-space:nowrap;max-width:120px;font-size:9px;overflow:hidden}.shape-lib-custom-list{flex-direction:column;gap:4px;margin-bottom:6px;display:flex}.shape-lib-custom-list .shape-lib-item{border:1px solid var(--border);background:#141414;justify-content:space-between;padding:4px 6px}.shape-lib-delete-btn{border:1px solid var(--border);color:var(--text-dim);cursor:pointer;background:0 0;flex-shrink:0;justify-content:center;align-items:center;width:18px;height:18px;margin-left:auto;padding:0;font-size:12px;line-height:1;display:flex}.shape-lib-delete-btn:hover{color:var(--text-bright);border-color:var(--text-dim)}.shape-lib-empty{color:var(--text-dim);margin-bottom:6px;font-size:9px;font-style:italic}.shape-lib-upload-row{align-items:center;gap:8px;margin-bottom:4px;display:flex}.shape-lib-hint{color:var(--text-dim);letter-spacing:.04em;white-space:nowrap;font-size:8px}.shape-lib-upload-error{color:#e07070;margin-top:4px;font-size:9px}.shape-lib-upload-warning{color:#d4a24e;margin-top:4px;font-size:9px}.shape-dropdown-group{color:var(--label);letter-spacing:.12em;text-transform:uppercase;border-bottom:1px solid var(--border);pointer-events:none;padding:4px 8px 2px;font-size:8px}.module-warning{color:#d4a24e;letter-spacing:.02em;padding:2px 0;font-size:8px}.btn-secondary.is-copied{color:var(--text-bright);border-color:var(--text-dim)}.about-content p{color:var(--text-dim);margin-bottom:8px;font-size:11px;line-height:1.6}.about-content p:last-child{margin-bottom:0}.about-content a{color:var(--accent);text-decoration:none}.about-content a:hover{text-decoration:underline}#export-dialog{background:var(--surface);color:var(--text);border:1px solid var(--border-accent);border-radius:4px;min-width:320px;margin:auto;padding:24px;font-family:IBM Plex Mono,monospace;font-size:11px}#export-dialog::backdrop{background:#000000a6}.export-form{flex-direction:column;gap:16px;display:flex}.export-form h2{letter-spacing:.12em;text-transform:uppercase;color:var(--text-bright);font-size:11px;font-weight:500}.form-row{color:var(--text);align-items:center;gap:10px;display:flex}.form-row select,.form-row input[type=number]{background:var(--bg);border:1px solid var(--border-accent);color:var(--text-bright);border-radius:2px;min-width:70px;padding:4px 6px;font-family:IBM Plex Mono,monospace;font-size:11px}.format-group{border:none;gap:16px;padding:0;display:flex}.format-group legend{color:var(--text);float:left;width:100%;margin-bottom:6px;font-size:11px}.format-group label{color:var(--text);cursor:pointer;align-items:center;gap:6px;display:flex}.png-height-readout{color:var(--text-dim);white-space:nowrap;font-size:10px}.png-width-row.is-hidden{display:none}.dialog-actions{justify-content:flex-end;gap:8px;padding-top:4px;display:flex}.mobile-topbar,.mobile-dice,.mobile-generate-btn,.sidebar-overlay{display:none}@media (width<=768px){body{overflow:hidden}.app{flex-direction:column;height:100dvh}.sidebar{z-index:100;width:85%;max-width:350px;transition:left .25s ease-out;position:fixed;top:0;bottom:0;left:-100%;overflow-y:auto}.sidebar.is-open{left:0}.sidebar-section--actions{display:none}.canvas-area{flex:1;padding:64px 16px 88px;overflow:hidden}.sidebar-overlay{z-index:99;background:#00000080;display:block;position:fixed;inset:0}.sidebar-overlay[hidden]{display:none}.mobile-topbar{background:var(--bg);border-bottom:1px solid var(--border);z-index:50;justify-content:space-between;align-items:center;height:56px;padding:0 12px;display:flex;position:fixed;top:0;left:0;right:0}.mobile-dice{z-index:40;display:flex;position:fixed;top:68px;left:50%;transform:translate(-50%)}.mobile-generate-btn{border:1px solid var(--accent);height:52px;color:var(--text-bright);letter-spacing:.15em;text-transform:uppercase;cursor:pointer;z-index:50;background:0 0;border-radius:2px;font-family:IBM Plex Mono,monospace;font-size:11px;display:block;position:fixed;bottom:16px;left:16px;right:16px}.mobile-generate-btn:hover{background:#ffffff0d}.mobile-icon-btn{width:44px;height:44px;color:var(--text-bright);cursor:pointer;background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;display:flex}.mobile-icon-btn:hover{background:#ffffff0f}}
