:root{--bg-dark: #000000;--bg-light: #f5f5f5;--text-dark: #1a1a1a;--text-light: #f0f0f0;--panel-bg-dark: #1e1e1e;--panel-bg-light: #ffffff;--scene-bg-dark: #1a1a1a;--scene-bg-light: #f0f0f0;--primary-accent: #66c2a5;--secondary-accent: #fd8d62;--border-color-dark: #444;--border-color-light: #ddd;--shadow-light: 0 4px 12px rgba(0,0,0,.1);--shadow-dark: 0 4px 12px rgba(0,0,0,.4);--gap: clamp(10px, .9vw, 18px);--panel-width: clamp(260px, 19vw, 400px);--container-margin: clamp(10px, .9vw, 20px);--adjust-pill-menu-gap: 10px;--ui-font-size: clamp(.85rem, .7vw + .55rem, 1.05rem);--app-top-bar-height: clamp(54px, 3.4vw + 10px, 70px);--floater-offset-left: calc(var(--container-margin) + var(--panel-width) + var(--gap) + 15px);--floater-offset-top: calc(var(--container-margin) + var(--app-top-bar-height) + var(--gap));--pill-icon-base: #2d2d2d;--pill-icon-hover: #3a3a3a;--pill-octagon-stroke: #4fc3f7;--pill-primary-accent: #FFAF89;--pill-secondary-accent: #924827;--pill-button-text: #f0f0f0;--pill-button-border: rgba(255, 255, 255, .12)}body{position:relative;height:100vh;margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;background-color:var(--bg-dark);color:var(--text-light);overflow:hidden;transition:background-color .3s ease,color .3s ease;box-sizing:border-box}body.light-theme{background-color:var(--bg-light);color:var(--text-dark);--pill-icon-base: #ebebeb;--pill-icon-hover: #dddddd;--pill-octagon-stroke: #2196f3;--pill-primary-accent: #d2693e;--pill-secondary-accent: #8d4925;--pill-button-text: #1a1a1a;--pill-button-border: rgba(0, 0, 0, .12)}body.landing-page{display:flex;justify-content:center;align-items:center;height:100vh;text-align:center;overflow:auto;background-color:var(--panel-bg-dark)}body.landing-page.light-theme{background-color:var(--panel-bg-light)}.landing-page .container{background-color:var(--panel-bg-dark);padding:40px 50px;border-radius:12px;border:1px solid var(--border-color-dark);box-shadow:var(--shadow-dark)}.landing-page h1{margin-top:0;margin-bottom:30px;font-weight:600}.nav-button{display:inline-block;padding:15px 30px;background-color:var(--primary-accent);color:#000;text-decoration:none;font-size:1rem;font-weight:500;border-radius:8px;border:none;cursor:pointer;transition:transform .2s ease,opacity .2s ease}.nav-button:hover{opacity:.9;transform:scale(1.05)}canvas{display:block;position:absolute;top:0;left:0;right:0;bottom:0;width:100%;height:100%;z-index:1}#label-container{position:absolute;top:0;left:0;right:0;bottom:0;width:100%;height:100%;pointer-events:none;z-index:50;overflow:hidden}.label{color:var(--text-light);background:#0009;padding:2px 5px;border-radius:4px;font-size:12px;pointer-events:none}body.light-theme .label{color:var(--text-dark);background:#ffffffb3;border:1px solid var(--border-color-light)}#ui-container{position:absolute;top:var(--floater-offset-top);left:var(--container-margin);width:var(--panel-width);height:calc(100vh - var(--floater-offset-top) - var(--container-margin));max-height:calc(100vh - var(--floater-offset-top) - var(--container-margin));background-color:#4b4b4b14;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-radius:20px;padding:16px;box-sizing:border-box;box-shadow:0 8px 24px #0000004d;border:1px solid rgba(100,100,100,.3);transition:background-color .3s ease,border-color .3s ease,transform .3s ease-in-out;overflow-y:auto;display:flex;flex-direction:column;gap:16px;z-index:100}body.light-theme #ui-container{background-color:#ffffff1a;border-color:#c8c8c833;box-shadow:0 8px 24px #0000001f}.icon-title{margin-right:6px;font-size:.85rem;opacity:.7}.ui-section{padding:12px;border:1px solid var(--border-color-dark);border-radius:8px;display:flex;flex-direction:column;gap:12px;transition:border-color .3s ease}body.light-theme .ui-section{border-color:var(--border-color-light)}.ui-title{font-weight:600;font-size:1rem;margin:0;padding-bottom:8px;border-bottom:1px solid var(--border-color-dark);transition:border-color .3s ease}body.light-theme .ui-title{border-color:var(--border-color-light)}.control-row{display:flex;justify-content:space-between;align-items:center;gap:10px}.border-actions{display:flex;flex-direction:column;gap:6px;flex-grow:1}.border-actions .panel-btn{width:100%;justify-content:flex-start}.control-row-stack-buttons{align-items:flex-start}label{font-size:.9rem}button{padding:8px 12px;border-radius:6px;border:1px solid var(--border-color-dark);background-color:#000;color:var(--text-light);font-size:.9rem;transition:background-color .2s,border-color .2s,opacity .2s;cursor:pointer}input[type=number]{padding:8px 12px;border-radius:6px;border:1px solid var(--border-color-dark);background-color:#000;color:var(--text-light);font-size:.9rem;transition:background-color .2s,border-color .2s;width:70px;text-align:right;-moz-appearance:textfield}input::-webkit-outer-spin-button,input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}button:not(.hex-button):not(.icon-btn):not(.fab):not(.custom-select-button):not(.control-btn):not(.icon-btn-svg-wrapper):not(.angle-preset-button):not(.floater-stepper-btn):not(.inner-dl-step-btn):not(.skip-btn):not(.motif-n-btn):not(.motif-action-btn):not(.download-fab-btn):not(.layer-options-btn):not(.studio-add-btn):not(.studio-row-btn):not(.studio-edit-done-btn):not(.visibility-toggle):not(.layer-texture-btn):not(.layer-texture-clear-btn):not(.studio-mode-btn):not(.rotate-popover-reset):not(.rotate-popover-preset){width:100%;background-color:var(--primary-accent);color:#000;border:none;font-weight:500}body.light-theme button,body.light-theme input[type=number]{background-color:#eee;color:var(--text-dark);border-color:var(--border-color-light)}body.light-theme button:not(.hex-button):not(.icon-btn):not(.fab):not(.custom-select-button):not(.control-btn):not(.icon-btn-svg-wrapper):not(.angle-preset-button):not(.floater-stepper-btn):not(.inner-dl-step-btn):not(.skip-btn):not(.motif-n-btn):not(.motif-action-btn):not(.download-fab-btn):not(.layer-options-btn):not(.studio-add-btn):not(.studio-row-btn):not(.studio-edit-done-btn):not(.visibility-toggle):not(.layer-texture-btn):not(.layer-texture-clear-btn):not(.studio-mode-btn):not(.rotate-popover-reset):not(.rotate-popover-preset){background-color:var(--primary-accent);color:#fff}button:hover,input[type=number]:hover{border-color:var(--primary-accent)}button:hover:not(.hex-button):not(.icon-btn-svg-wrapper){opacity:.9}.slider-container{display:flex;align-items:center;gap:8px}input[type=range]{-webkit-appearance:none;flex-grow:1;height:4px;background:var(--border-color-dark);border-radius:2px;outline:none;transition:background .3s}body.light-theme input[type=range]{background:var(--border-color-light)}input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:16px;height:16px;background:var(--primary-accent);cursor:pointer;border-radius:50%}.stepper-btn{width:24px;height:24px;padding:0;font-size:1rem;line-height:24px;text-align:center;flex-shrink:0}.tessellate-legend{display:none}.custom-tiling-controls{display:flex;flex-direction:column;gap:8px}.custom-tiling-controls .panel-btn{width:100%}.custom-tiling-floater{display:flex;flex-wrap:wrap;align-items:center;gap:8px;padding:10px 12px;margin-top:10px;box-sizing:border-box;background-color:#2c2c2cb3;border:1px solid rgba(255,255,255,.2);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border-radius:10px}#ui-container .custom-tiling-floater{width:100%}#ui-container .custom-tiling-floater .hex-button{flex:1 1 0}body.light-theme .custom-tiling-floater{background-color:#ffffffb3;border:1px solid rgba(0,0,0,.1)}.custom-tiling-floater[hidden]{display:none}.custom-tiling-status{font-size:.7rem;color:var(--text-muted, #aaa);line-height:1.3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:220px}.custom-tiling-status.is-error{color:#e57373}.button-group{display:flex;gap:10px;justify-content:center}#pattern-controls-container{display:flex;flex-direction:column;gap:12px}.panel-btn{display:flex;align-items:center;justify-content:center;gap:8px;padding:10px 14px;border-radius:8px;border:1px solid var(--border-color-dark);font-size:.85rem;font-weight:500;cursor:pointer;transition:background-color .2s,transform .1s,border-color .2s;width:100%;box-sizing:border-box}.panel-btn:hover{transform:scale(1.02);opacity:.9}.panel-btn:active{transform:scale(.98)}body.light-theme .panel-btn{border-color:var(--border-color-light)}.panel-btn i{font-size:1rem;flex-shrink:0}.panel-btn-truncate{background-color:color-mix(in srgb,var(--pill-primary-accent) 15%,transparent)!important;color:var(--pill-primary-accent)!important;border:1px solid color-mix(in srgb,var(--pill-primary-accent) 30%,transparent)!important;margin-top:4px}.panel-btn-truncate:hover{background-color:color-mix(in srgb,var(--pill-primary-accent) 30%,transparent)!important;border-color:var(--pill-primary-accent)!important;color:#fff!important}body.light-theme .panel-btn-truncate{background-color:color-mix(in srgb,var(--pill-primary-accent) 12%,transparent)!important;color:var(--pill-primary-accent)!important;border-color:color-mix(in srgb,var(--pill-primary-accent) 28%,transparent)!important}body.light-theme .panel-btn-truncate:hover{background-color:color-mix(in srgb,var(--pill-primary-accent) 22%,transparent)!important;color:#fff!important}.truncate-target{font-size:.7rem;opacity:.5;margin-left:auto;white-space:nowrap}.panel-btn-truncate.is-disabled{opacity:.3;cursor:not-allowed;pointer-events:none}.panel-btn-detruncate{background-color:#eab30826;color:#fbbf24;border:1px solid rgba(234,179,8,.3);margin-top:4px}.panel-btn-detruncate:hover{background-color:#eab3084d;border-color:#eab308;color:#fff}body.light-theme .panel-btn-detruncate{background-color:#eab3081a;color:#a16207;border-color:#eab30840}body.light-theme .panel-btn-detruncate:hover{background-color:#eab30833;color:#854d0e}.detruncate-target{font-size:.7rem;opacity:.5;margin-left:auto;white-space:nowrap}.panel-btn-detruncate.is-disabled{opacity:.3;cursor:not-allowed;pointer-events:none}.history-fab{position:fixed;bottom:20px;left:var(--container-margin);width:max-content;height:clamp(54px,calc(3.4vw + 10px),70px);box-sizing:border-box;z-index:1002;display:flex;flex-direction:row;align-items:center;justify-content:center;gap:8px;padding:0 clamp(12px,1vw,18px);border-radius:14px;background-color:#4b4b4b14;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(100,100,100,.3);box-shadow:0 8px 24px #0000004d}body.light-theme .history-fab{background-color:#ffffff1a;border-color:#c8c8c833;box-shadow:0 8px 24px #0000001f}.history-fab .panel-btn{width:clamp(36px,2.8vw,50px)!important;height:clamp(36px,2.8vw,50px)!important;min-width:0;min-height:0;aspect-ratio:1 / 1;padding:0;border-radius:8px;display:flex;align-items:center;justify-content:center;background-color:#4b4b4b4d!important;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);color:var(--pill-button-text)!important;border:1px solid rgba(100,100,100,.3);font-size:clamp(.85rem,.5vw + .5rem,1.2rem);transition:background-color .2s,transform .1s,color .2s,border-color .2s;flex:0 0 auto;box-shadow:none;gap:0}.history-fab .panel-btn span{display:none}.history-fab .panel-btn i{font-size:inherit}.history-fab .panel-btn:hover:not(.is-disabled){background-color:color-mix(in srgb,var(--pill-primary-accent) 22%,transparent)!important;border-color:color-mix(in srgb,var(--pill-primary-accent) 75%,transparent)!important;color:var(--pill-primary-accent)!important;box-shadow:0 0 0 1px color-mix(in srgb,var(--pill-primary-accent) 35%,transparent) inset,0 4px 12px #0000004d;transform:translateY(-1px);opacity:1}.history-fab .panel-btn:hover:not(.is-disabled) i{color:var(--pill-primary-accent)!important}.history-fab .panel-btn:active:not(.is-disabled){transform:translateY(0) scale(.96)}.history-fab .panel-btn.is-disabled{opacity:.35;cursor:not-allowed}body.light-theme .history-fab .panel-btn{background-color:#ffffff80!important;color:var(--pill-button-text)!important;border-color:#0000001a}body.light-theme .history-fab .panel-btn:hover:not(.is-disabled){background-color:#9248271f!important;border-color:#92482780!important;color:#924827!important}body.light-theme .history-fab .panel-btn:hover:not(.is-disabled) i{color:#924827!important}.undo-redo-group{display:flex;gap:8px}.undo-redo-group .panel-btn{flex:1}.panel-btn-undo{background-color:#ffffff14;color:var(--text-light);border:1px solid rgba(255,255,255,.15)}.panel-btn-undo:hover:not(.is-disabled){background-color:#ffffff26;border-color:var(--secondary-accent);color:var(--secondary-accent)}body.light-theme .panel-btn-undo{background-color:#0000000a;color:var(--text-dark);border-color:#0000001a}body.light-theme .panel-btn-undo:hover:not(.is-disabled){background-color:#00000014;border-color:var(--secondary-accent);color:var(--secondary-accent)}.panel-btn-redo{background-color:#ffffff14;color:var(--text-light);border:1px solid rgba(255,255,255,.15)}.panel-btn-redo:hover:not(.is-disabled){background-color:#ffffff26;border-color:var(--primary-accent);color:var(--primary-accent)}body.light-theme .panel-btn-redo{background-color:#0000000a;color:var(--text-dark);border-color:#0000001a}body.light-theme .panel-btn-redo:hover:not(.is-disabled){background-color:#00000014;border-color:var(--primary-accent);color:var(--primary-accent)}.panel-btn.is-disabled{opacity:.3;cursor:not-allowed;pointer-events:none}.export-btn-group{display:flex;gap:8px}.export-btn-group .panel-btn{flex:1}.panel-btn-dxf,.panel-btn-stl,.panel-btn-pdf,.panel-btn-png{background-color:color-mix(in srgb,var(--pill-primary-accent) 15%,transparent)!important;color:var(--pill-primary-accent)!important;border-color:color-mix(in srgb,var(--pill-primary-accent) 30%,transparent)!important}.panel-btn-dxf:hover,.panel-btn-stl:hover,.panel-btn-pdf:hover,.panel-btn-png:hover{background-color:color-mix(in srgb,var(--pill-primary-accent) 30%,transparent)!important;border-color:var(--pill-primary-accent)!important;color:#fff!important}body.light-theme .panel-btn-dxf,body.light-theme .panel-btn-stl,body.light-theme .panel-btn-pdf,body.light-theme .panel-btn-png{background-color:color-mix(in srgb,var(--pill-primary-accent) 12%,transparent)!important;color:var(--pill-primary-accent)!important;border-color:color-mix(in srgb,var(--pill-primary-accent) 28%,transparent)!important}body.light-theme .panel-btn-dxf:hover,body.light-theme .panel-btn-stl:hover,body.light-theme .panel-btn-pdf:hover,body.light-theme .panel-btn-png:hover{background-color:color-mix(in srgb,var(--pill-primary-accent) 22%,transparent)!important;color:#fff!important}.fab-group{display:flex;flex-direction:row;justify-content:space-around;align-items:center;padding:10px 0 20px;gap:10px}#mobile-menu-btn{display:none;position:absolute;top:15px;left:15px;z-index:101;width:45px;height:45px;font-size:24px;background-color:var(--panel-bg-dark);color:var(--text-light);border:1px solid var(--border-color-dark);border-radius:8px;cursor:pointer}body.light-theme #mobile-menu-btn{background-color:var(--panel-bg-light);color:var(--text-dark);border-color:var(--border-color-light)}@media (max-width: 1024px){canvas,#label-container{left:350px;right:15px}.custom-select-container{left:var(--floater-offset-left);top:var(--floater-offset-top)}.canvas-overlay-buttons{right:30px;bottom:40px;top:auto}}@media (max-width: 768px){#mobile-menu-btn{display:block;top:calc(var(--container-margin) + var(--app-top-bar-height) + var(--gap));left:15px}#ui-container{transform:translate(-110%);background-color:#2c2c2cbf;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);width:280px;height:auto;box-shadow:var(--shadow-dark)}body.light-theme #ui-container{background-color:#ffffffbf}#ui-container.is-open{transform:translate(0)}canvas,#label-container{left:0;right:0;top:0;bottom:0;border-radius:0}.custom-select-container{top:70px;left:10px;width:calc(100% - 20px);max-width:none;flex-direction:column}.canvas-overlay-buttons{top:15px;right:15px;bottom:auto;flex-direction:row;gap:10px}.canvas-overlay-buttons .icon-btn{width:44px;height:44px}}#layers-panel .layer-group,.studio-side-panel .layer-group{margin-bottom:8px}#layers-panel summary,.studio-side-panel .layer-group>summary{font-weight:500;cursor:pointer;padding:4px;list-style:none}#layers-panel summary:before,.studio-side-panel .layer-group>summary:before{content:"▶";display:inline-block;margin-right:8px;font-size:.7em;transition:transform .2s}#layers-panel details[open]>summary:before,.studio-side-panel details.layer-group[open]>summary:before{transform:rotate(90deg)}#layers-panel .layer-items,.studio-side-panel .layer-items{padding-left:15px;display:flex;flex-direction:column;gap:8px;margin-top:8px}#layers-panel .layer-row,.studio-side-panel .layer-row{display:flex;align-items:center;gap:8px;justify-content:flex-start}#layers-panel .layer-row.layer-disabled{opacity:.4;pointer-events:none;filter:grayscale(1)}.layer-texture-btn{width:22px;height:22px;border:none!important;background:transparent!important;color:#ffffff8c;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;margin-left:auto;font-size:12px}.layer-texture-btn:hover{color:#ffffffe6}.layer-texture-btn.has-texture{color:var(--pill-primary-accent, #ffaf89)}body.light-theme .layer-texture-btn{color:#0000008c}body.light-theme .layer-texture-btn:hover{color:#000000d9}.layer-texture-clear-btn{width:18px;height:22px;border:none!important;background:transparent!important;color:#ffffff73;cursor:pointer;display:none;align-items:center;justify-content:center;padding:0;font-size:11px;margin-left:2px}.layer-texture-clear-btn:hover{color:#ffffffe6}body.light-theme .layer-texture-clear-btn{color:#00000073}body.light-theme .layer-texture-clear-btn:hover{color:#000000d9}#layers-panel .layer-name,.studio-side-panel .layer-name{flex-grow:1}.dxf-format-modal{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100000;display:none;align-items:center;justify-content:center}.dxf-format-modal.is-visible{display:flex}.dxf-format-modal-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;background:#0000008c;backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px)}.dxf-format-modal-box{position:relative;background:var(--panel-bg, #1f1f24);color:#fff;border:1px solid var(--border-color-dark, #3a3a40);border-radius:12px;padding:22px 22px 18px;width:min(420px,calc(100% - 32px));box-shadow:0 18px 50px #0000008c;display:flex;flex-direction:column;gap:12px}body.light-theme .dxf-format-modal-box{background:#fff;color:#1a1a1a;border-color:var(--border-color-light, #d8d8d8)}.dxf-format-modal-title{font-size:1.05rem;font-weight:600;margin:0}.dxf-format-modal-subtitle{font-size:.85rem;opacity:.7;margin:0 0 6px}.dxf-format-option{display:flex;align-items:center;gap:12px;width:100%;text-align:left;padding:12px 14px;background:#ffffff0a;border:1px solid var(--border-color-dark, #3a3a40);border-radius:10px;color:inherit;cursor:pointer;transition:background .15s,transform .1s,border-color .15s;font-family:inherit}body.light-theme .dxf-format-option{background:#00000006;border-color:var(--border-color-light, #d8d8d8)}.dxf-format-option:hover{background:#ffffff14;border-color:var(--pill-primary-accent, #ffaf89)}body.light-theme .dxf-format-option:hover{background:#0000000f}.dxf-format-option:active{transform:scale(.99)}.dxf-format-option-icon{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:8px;background:#ffaf892e;color:var(--pill-primary-accent, #ffaf89);font-size:1.1rem;flex-shrink:0}.dxf-format-option-text{display:flex;flex-direction:column;gap:2px}.dxf-format-option-text strong{font-size:.95rem;font-weight:600}.dxf-format-option-text span{font-size:.8rem;opacity:.7}.dxf-format-cancel{margin-top:4px;padding:8px;background:transparent;border:none;color:inherit;opacity:.6;font-size:.85rem;cursor:pointer;font-family:inherit}.dxf-format-cancel:hover{opacity:1}.layer-options-btn,.layer-options-btn:hover,.layer-options-btn:focus{width:14px;height:14px;border:none!important;background:transparent!important;color:#ffffff73;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:11px;padding:0;flex-shrink:0;outline:none;box-shadow:none}.layer-options-btn:hover{color:#fff}body.light-theme .layer-options-btn,body.light-theme .layer-options-btn:hover,body.light-theme .layer-options-btn:focus{color:#00000080}body.light-theme .layer-options-btn:hover{color:#000}.layer-style-menu{position:fixed;z-index:2000;min-width:220px;padding:12px;background:#1e1e1eeb;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.15);border-radius:10px;box-shadow:0 12px 32px #0006;display:flex;flex-direction:column;gap:10px;font-size:.8rem;color:var(--text-light)}.layer-style-menu.is-hidden{display:none}.layer-style-menu .menu-row{display:flex;align-items:center;justify-content:space-between;gap:10px}.layer-style-menu .menu-row label{font-size:.75rem;opacity:.75}.layer-style-menu .style-btn-group{display:flex;gap:4px}.layer-style-menu .style-btn{width:36px;height:28px;background:#ffffff0f;border:1px solid rgba(255,255,255,.12);border-radius:5px;color:#fffc;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;font-size:11px}.layer-style-menu .style-btn:hover{background:#ffffff24}.layer-style-menu .style-btn.is-active{background:#5b8def;border-color:#5b8def;color:#fff}.layer-style-menu input[type=range]{flex-grow:1}.layer-style-menu .style-value{min-width:28px;text-align:right;font-variant-numeric:tabular-nums}.layer-style-menu .style-hint{font-size:.65rem;opacity:.55;line-height:1.3}body.light-theme .layer-style-menu{background:#fffffff5;border-color:#0000001f;color:var(--text-dark)}body.light-theme .layer-style-menu .style-btn{background:#0000000a;border-color:#0000001f;color:#000000c7}body.light-theme .layer-style-menu .style-btn:hover{background:#00000014}.custom-color-picker{position:relative}.color-swatch{width:18px;height:18px;border:1px solid var(--border-color-dark);border-radius:4px;cursor:pointer}body.light-theme .color-swatch{border-color:var(--border-color-light)}.color-palette{display:none;position:absolute;top:100%;left:0;margin-top:4px;background-color:var(--panel-bg-dark);border:1px solid var(--border-color-dark);border-radius:6px;box-shadow:var(--shadow-dark);padding:6px;z-index:1000;width:150px}.color-palette.is-open{display:block}body.light-theme .color-palette{background-color:var(--panel-bg-light);border-color:var(--border-color-light);box-shadow:var(--shadow-light)}.palette-item{display:flex;align-items:center;gap:8px;padding:6px;border-radius:4px;cursor:pointer}.palette-item:hover{background-color:color-mix(in srgb,var(--pill-primary-accent) 22%,transparent);color:var(--pill-primary-accent)}.palette-item.palette-default .palette-name{font-weight:600}.palette-color{width:14px;height:14px;border-radius:3px;border:1px solid var(--border-color-dark)}body.light-theme .palette-item:hover .palette-color{border-color:#fff}.color-palette hr{border:none;border-top:1px solid var(--border-color-dark);margin:6px 0}body.light-theme .color-palette hr{border-color:var(--border-color-light)}#layers-panel .visibility-toggle,.studio-side-panel .visibility-toggle{background:none;border:none;color:var(--text-light);cursor:pointer;padding:4px;width:24px;height:24px;font-size:1rem}body.light-theme #layers-panel .visibility-toggle,body.light-theme .studio-side-panel .visibility-toggle{color:var(--text-dark)}#layers-panel .visibility-toggle.is-hidden .fa-solid,.studio-side-panel .visibility-toggle.is-hidden .fa-solid{opacity:.3}.switch{position:relative;display:inline-block;width:44px;height:24px}.switch input{opacity:0;width:0;height:0}.switch .slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:#444;transition:.4s;border-radius:24px}.switch .slider:before{position:absolute;content:"";height:18px;width:18px;left:3px;bottom:3px;background-color:#fff;transition:.4s;border-radius:50%}.switch input:checked+.slider{background-color:var(--primary-accent)}.switch input:checked+.slider:before{transform:translate(20px)}#theme-toggle-row{width:auto}#theme-toggle-row .switch{width:70px;height:34px;flex-shrink:0}#theme-toggle-row .slider{position:absolute;top:0;left:0;right:0;bottom:0;background-color:#3a3a3a;border-radius:34px;transition:background-color .3s ease-in-out;cursor:pointer}#theme-toggle-row .slider:before{content:"";position:absolute;top:4px;left:4px;width:26px;height:26px;background-color:#f0f0f0;border-radius:50%;transition:transform .3s cubic-bezier(.175,.885,.32,1.275);z-index:1}#theme-toggle-row .sun-icon,#theme-toggle-row .moon-icon{position:absolute;top:4px;left:4px;width:26px;height:26px;padding:5px;box-sizing:border-box;pointer-events:none;transition:transform .3s cubic-bezier(.175,.885,.32,1.275),opacity .3s ease-in-out;z-index:2}#theme-toggle-row .moon-icon{stroke:var(--text-dark);opacity:1;transform:translate(0) rotate(0)}#theme-toggle-row .sun-icon{stroke:#f5f5f5;opacity:0;transform:translate(0) rotate(90deg)}body.light-theme #theme-toggle-row .slider{background-color:var(--primary-accent)}#theme-toggle-row input:checked+.slider:before{transform:translate(36px)}#theme-toggle-row input:checked~.slider .moon-icon{opacity:0;transform:translate(36px) rotate(-90deg)}#theme-toggle-row input:checked~.slider .sun-icon{stroke:var(--text-dark);opacity:1;transform:translate(36px) rotate(0)}.hidden{display:none!important}.app-tooltip{position:fixed;background:#141414eb;color:#fff;padding:5px 10px;border-radius:6px;font-size:12px;font-weight:500;letter-spacing:.01em;white-space:nowrap;pointer-events:none;z-index:10000;box-shadow:0 4px 12px #00000059;opacity:0;transform:translateY(-2px);transition:opacity .12s ease-out,transform .12s ease-out}.app-tooltip.visible{opacity:1;transform:translateY(0)}body.light-theme .app-tooltip{background:#fffffff5;color:#111;box-shadow:0 4px 12px #0003}@media (hover: none){.app-tooltip{display:none!important}}.pill-fab-container{position:fixed;bottom:var(--gap);left:0;right:0;margin:0 auto;width:max-content;z-index:1001;display:flex;flex-direction:column;align-items:center}.icon-btn{width:clamp(48px,4vw,76px);height:clamp(48px,4vw,76px);color:#fff;font-weight:600;font-size:clamp(.95rem,.7vw + .5rem,1.4rem);display:flex;align-items:center;justify-content:center;transition:all .3s ease-in-out,box-shadow .3s ease-in-out;cursor:pointer;position:relative;flex-shrink:0;border-radius:50%;box-shadow:0 4px 6px #0000004d;background:none;border:none;padding:0}#grid-toggle-fab,#presentation-toggle-fab,#theme-toggle-fab,#view3d-toggle-fab,#load-project-fab,#unit-toggle-fab,#snap-toggle-fab{background-color:#4b4b4b4d;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(100,100,100,.3);color:var(--pill-button-text);transition:background-color .2s,transform .1s,color .2s,border-color .2s}#grid-toggle-fab:hover,#presentation-toggle-fab:hover,#theme-toggle-fab:hover,#view3d-toggle-fab:hover,#load-project-fab:hover,#unit-toggle-fab:hover,#snap-toggle-fab:hover{background-color:color-mix(in srgb,var(--pill-primary-accent) 22%,transparent);border-color:color-mix(in srgb,var(--pill-primary-accent) 75%,transparent);color:var(--pill-primary-accent);box-shadow:0 0 0 1px color-mix(in srgb,var(--pill-primary-accent) 35%,transparent) inset,0 4px 12px #0000004d;transform:translateY(-1px)}#grid-toggle-fab:hover i,#presentation-toggle-fab:hover i,#theme-toggle-fab:hover i,#view3d-toggle-fab:hover i,#load-project-fab:hover i,#snap-toggle-fab:hover i,#unit-toggle-fab:hover .unit-toggle-label{color:var(--pill-primary-accent)}#grid-toggle-fab:active,#presentation-toggle-fab:active,#theme-toggle-fab:active,#view3d-toggle-fab:active,#load-project-fab:active,#unit-toggle-fab:active,#snap-toggle-fab:active{transform:translateY(0) scale(.96)}#presentation-toggle-fab.is-on,#theme-toggle-fab.is-on,#view3d-toggle-fab.is-on,#edit-mode-fab.is-on,#snap-toggle-fab.is-on{background-color:var(--pill-primary-accent);border-color:var(--pill-primary-accent);color:#000}#grid-toggle-fab.is-off{opacity:.55}#theme-toggle-fab,#presentation-toggle-fab,#view3d-toggle-fab,#edit-mode-fab,#grid-toggle-fab{position:relative;overflow:visible}#theme-toggle-fab:after,#presentation-toggle-fab:after,#view3d-toggle-fab:after,#edit-mode-fab:after,#grid-toggle-fab:after{content:"";position:absolute;left:50%;bottom:-5px;transform:translate(-50%);width:0;height:2px;border-radius:1px;background-color:var(--pill-primary-accent);transition:width .2s ease;pointer-events:none}#theme-toggle-fab.is-on:after,#presentation-toggle-fab.is-on:after,#view3d-toggle-fab.is-on:after,#edit-mode-fab.is-on:after{width:14px}#grid-toggle-fab:not(.is-off):after{width:14px}body.light-theme #grid-toggle-fab,body.light-theme #presentation-toggle-fab,body.light-theme #theme-toggle-fab,body.light-theme #view3d-toggle-fab,body.light-theme #load-project-fab,body.light-theme #unit-toggle-fab{background-color:#ffffff80;border-color:#0000001a;color:var(--pill-button-text)}body.light-theme #grid-toggle-fab:hover,body.light-theme #presentation-toggle-fab:hover,body.light-theme #theme-toggle-fab:hover,body.light-theme #view3d-toggle-fab:hover,body.light-theme #load-project-fab:hover,body.light-theme #unit-toggle-fab:hover{background-color:#9248271f;border-color:#92482780;color:#924827}#unit-toggle-fab .unit-toggle-label{font-size:clamp(.7rem,.4vw + .55rem,.95rem);font-weight:600;line-height:1;pointer-events:none;color:inherit}#top-right-fabs>#unit-toggle-fab,#top-right-fabs>#load-project-fab{margin-left:clamp(10px,1.1vw,18px)}.icon-btn:hover{transform:scale(1.05);box-shadow:0 6px 10px #0006;opacity:1;border-color:transparent}.icon-btn svg{position:absolute;top:0;left:0;width:100%;height:100%;transition:filter .3s ease-in-out}.circle-base-shape{fill:var(--pill-icon-base);transition:fill .3s ease-in-out,filter .3s ease-in-out}.icon-btn:hover .circle-base-shape{fill:var(--pill-icon-hover)}.octagon-icon-shape{fill:var(--pill-icon-base);stroke:var(--pill-octagon-stroke);stroke-width:2.5;transition:fill .3s ease-in-out,stroke .3s ease-in-out}.icon-btn:hover .octagon-icon-shape{fill:var(--pill-icon-hover);stroke:var(--pill-octagon-stroke)}.octagon-svg-star{opacity:1;stroke:var(--pill-primary-accent);stroke-width:2.5}.octagon-svg-star line{stroke-dasharray:57;stroke-dashoffset:57;transition:stroke-dashoffset .8s ease-in-out}.frosted-glass-container.expanded-level-1 #toggleButton .octagon-svg-star line,.frosted-glass-container.expanded-level-2 #toggleButton .octagon-svg-star line{stroke-dashoffset:0}.frosted-glass-container.expanded-level-2 #distanceToggleButton .octagon-svg-star line{stroke-dashoffset:0}.frosted-glass-container:not(.expanded-level-1):not(.expanded-level-2) #toggleButton:hover .octagon-svg-star line{animation:draw-star .8s ease-in-out .2s forwards}.frosted-glass-container.expanded-level-1 #distanceToggleButton:hover .octagon-svg-star line{animation:draw-star .8s ease-in-out .2s forwards}.frosted-glass-container.expanded-level-1 #toggleButton:hover .octagon-svg-star line,.frosted-glass-container.expanded-level-2 #toggleButton:hover .octagon-svg-star line{animation:erase-star .8s ease-in-out .2s forwards}.frosted-glass-container.expanded-level-2 #distanceToggleButton:hover .octagon-svg-star line{animation:erase-star .8s ease-in-out .2s forwards}.frosted-glass-container:not(.expanded-level-1):not(.expanded-level-2) #toggleButton:not(:hover) .octagon-svg-star line,.frosted-glass-container.expanded-level-1 #distanceToggleButton:not(:hover) .octagon-svg-star line{stroke-dashoffset:57!important}.frosted-glass-container.expanded-level-1 #toggleButton:not(:hover) .octagon-svg-star line,.frosted-glass-container.expanded-level-2 #toggleButton:not(:hover) .octagon-svg-star line,.frosted-glass-container.expanded-level-2 #distanceToggleButton:not(:hover) .octagon-svg-star line{stroke-dashoffset:0!important}@keyframes erase-star{0%{stroke-dashoffset:0}to{stroke-dashoffset:57}}@keyframes draw-star{0%{stroke-dashoffset:57}to{stroke-dashoffset:0}}.distance-icon-middle{stroke:var(--pill-primary-accent);stroke-width:3.5;stroke-dasharray:12 12}.distance-icon-double-lines line{stroke:var(--pill-secondary-accent);stroke-width:3.5;stroke-dasharray:80;stroke-dashoffset:80;transition:stroke-dashoffset .8s ease-in-out}.frosted-glass-container.expanded-level-2 #distanceToggleButton .distance-icon-double-lines line{stroke-dashoffset:0}.frosted-glass-container.expanded-level-1 #distanceToggleButton:hover .distance-icon-double-lines line{animation:draw-double-line .8s ease-in-out .2s forwards}.frosted-glass-container.expanded-level-2 #distanceToggleButton:hover .distance-icon-double-lines line{animation:erase-double-line .8s ease-in-out .2s forwards}.frosted-glass-container.expanded-level-1 #distanceToggleButton:not(:hover) .distance-icon-double-lines line{stroke-dashoffset:80!important}.frosted-glass-container.expanded-level-2 #distanceToggleButton:not(:hover) .distance-icon-double-lines line{stroke-dashoffset:0!important}@keyframes draw-double-line{0%{stroke-dashoffset:80}to{stroke-dashoffset:0}}@keyframes erase-double-line{0%{stroke-dashoffset:0}to{stroke-dashoffset:80}}.frosted-glass-container{background-color:#4b4b4b4d;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(100,100,100,.3);box-shadow:0 8px 24px #0000004d;display:flex;align-items:center;justify-content:center;width:clamp(64px,5.3vw,100px);height:clamp(64px,5.3vw,100px);border-radius:50%;transition:width .5s ease-in-out,border-radius .5s ease-in-out,justify-content .2s ease-in-out,padding .5s ease-in-out,gap .5s ease-in-out;overflow:hidden;gap:0;padding:0}body.light-theme .frosted-glass-container{background-color:#ffffff4d;border:1px solid rgba(200,200,200,.3)}.frosted-glass-container.expanded-level-1{width:clamp(502px,calc(266px + 19vw),618px);border-radius:9999px;justify-content:flex-start;padding:0 .5rem;gap:.5rem}.frosted-glass-container.expanded-level-2{width:clamp(896px,calc(520px + 30vw),1072px);border-radius:9999px;justify-content:flex-start;padding:0 .5rem;gap:.5rem}.pill-content{display:flex;align-items:center;gap:.5rem;white-space:nowrap;width:0;opacity:0;overflow:hidden;transition:opacity .3s ease-in-out .2s,width .5s ease-in-out;flex-shrink:0}.frosted-glass-container.expanded-level-1 .angle-pill-content,.frosted-glass-container.expanded-level-2 .angle-pill-content{width:clamp(372px,calc(232px + 11vw),432px);opacity:1}.frosted-glass-container.expanded-level-2 .distance-pill-content{width:clamp(404px,calc(264px + 11vw),464px);opacity:1}#distanceToggleButton{width:0;opacity:0;overflow:hidden;transition:opacity .3s ease-in-out .2s,width .5s ease-in-out}.frosted-glass-container.expanded-level-1 #distanceToggleButton,.frosted-glass-container.expanded-level-2 #distanceToggleButton{width:clamp(48px,4vw,76px);opacity:1}.angle-icon{color:var(--pill-primary-accent);stroke-width:3;width:48px;height:48px;flex-shrink:0;overflow:visible}body.light-theme .angle-icon{color:var(--pill-primary-accent)}#dynamicDistanceIcon #distanceLineMiddle{stroke:var(--pill-primary-accent)}#dynamicDistanceIcon #distanceLineTop,#dynamicDistanceIcon #distanceLineBottom{stroke:var(--pill-secondary-accent)}.control-btn{width:20px;height:20px;background-color:transparent;border:none;border-radius:0;color:var(--text-light);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:color .2s;font-size:1.1rem;line-height:1;flex-shrink:0;padding:0}body.light-theme .control-btn{color:var(--text-dark)}.control-btn:hover{color:#d1d5db;background-color:transparent}body.light-theme .control-btn:hover{color:#555}.pill-content md-slider{width:clamp(140px,11vw,200px);flex:0 0 auto;margin:0;block-size:16px;--md-slider-tint: var(--pill-primary-accent);--md-slider-active-track-color: var(--md-slider-tint);--md-slider-inactive-track-color: rgba(255, 255, 255, .3);--md-slider-active-track-height: 4px;--md-slider-inactive-track-height: 4px;--md-slider-active-track-shape: 2px;--md-slider-inactive-track-shape: 2px;--md-slider-handle-color: var(--md-slider-tint);--md-slider-handle-width: 16px;--md-slider-handle-height: 16px;--md-slider-pressed-handle-color: var(--md-slider-tint);--md-slider-hover-handle-color: var(--md-slider-tint);--md-slider-focus-handle-color: var(--md-slider-tint);--md-slider-state-layer-size: 16px;--md-slider-state-layer-color: var(--md-slider-tint)}body.light-theme .pill-content md-slider{--md-slider-inactive-track-color: rgba(0, 0, 0, .2)}.pill-content md-slider#distanceSlider{--md-slider-tint: var(--pill-secondary-accent)}.pill-content input[type=number]{width:32px;height:22px;text-align:center;border-radius:6px;border:1px solid var(--pill-button-border);background:var(--pill-icon-base);color:var(--pill-button-text);font-size:11px;font-family:inherit;padding:0 2px;margin-right:8px;flex-shrink:0;-moz-appearance:textfield;-webkit-appearance:textfield;appearance:textfield;transition:background-color .2s,border-color .2s}.pill-content input[type=number]:focus{outline:none;border-color:var(--pill-primary-accent)}.pill-content input[type=number]::-webkit-outer-spin-button,.pill-content input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.pill-content .distance-unit-suffix{display:inline-flex;align-items:center;margin-left:2px;margin-right:10px;color:var(--pill-secondary-accent);font-size:13px;font-weight:600;font-family:inherit;pointer-events:none;white-space:nowrap;letter-spacing:.02em}body.light-theme .pill-content .distance-unit-suffix{color:var(--pill-secondary-accent)}.pill-content #distanceNumber{margin-right:0}#widgetLegend{color:#aaa;font-size:.875rem;margin-top:1rem;text-align:center;transition:opacity .3s ease-in-out;height:1.25rem;line-height:1.25rem;pointer-events:none}body.light-theme #widgetLegend{color:#555}.frosted-glass-container.expanded-level-1+#widgetLegend,.frosted-glass-container.expanded-level-2+#widgetLegend{opacity:0}.custom-select-container{position:absolute;top:var(--floater-offset-top);left:calc(var(--container-margin) + var(--panel-width) + var(--container-margin));right:calc(var(--container-margin) + var(--panel-width) + var(--container-margin));transform:none;width:auto;z-index:100;display:flex;align-items:stretch;gap:0;padding:4px;border-radius:clamp(12px,1.1vw,18px);background-color:#2c2c2cb3;border:1px solid rgba(255,255,255,.2);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);box-shadow:0 8px 24px #0000004d}body.light-theme .custom-select-container{background-color:#ffffffb3;border-color:#0000001a}.custom-select-container>button.custom-select-button{background:transparent!important;border:none!important;box-shadow:none!important;backdrop-filter:none;-webkit-backdrop-filter:none}.custom-select-container>#tessellate-controls-floater #tessellate-container{background:transparent;border:none;backdrop-filter:none;-webkit-backdrop-filter:none;border-left:1px solid rgba(255,255,255,.15);border-radius:0;padding-left:clamp(10px,1vw,18px)}body.light-theme .custom-select-container>#tessellate-controls-floater #tessellate-container{border-left-color:#0000001f}#custom-tiling-select,#custom-polyhedron-select{width:clamp(280px,22vw,420px);flex-shrink:0}button.custom-select-button{box-sizing:border-box;display:flex;justify-content:space-between;align-items:center;width:100%;padding:clamp(4px,.4vw,8px) clamp(8px,.9vw,16px);height:clamp(44px,3.4vw,60px);font-size:var(--ui-font-size);text-align:left;cursor:pointer;transition:border-color .2s,background-color .2s;background-color:#2c2c2cb3;border:1px solid rgba(255,255,255,.2);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border-radius:10px;gap:15px}body.light-theme button.custom-select-button{background-color:#ffffffb3;border:1px solid rgba(0,0,0,.1);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);color:var(--text-dark)}button.custom-select-button:hover,button.custom-select-button.is-open{background-color:color-mix(in srgb,var(--pill-primary-accent) 18%,rgba(60,60,60,.7));border-color:color-mix(in srgb,var(--pill-primary-accent) 60%,transparent)}body.light-theme button.custom-select-button:hover,body.light-theme button.custom-select-button.is-open{background-color:color-mix(in srgb,var(--pill-primary-accent) 12%,rgba(255,255,255,.85));border-color:color-mix(in srgb,var(--pill-primary-accent) 50%,transparent)}.custom-select-icon-placeholder{width:clamp(24px,1.9vw,36px);height:clamp(24px,1.9vw,36px);background-color:#555;border-radius:5px;flex-shrink:0;display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.2rem;overflow:hidden}body.light-theme .custom-select-icon-placeholder{background-color:#ccc;color:#333}.custom-select-icon-placeholder svg{width:100%;height:100%;fill:currentColor}.custom-select-text-group{display:flex;flex-direction:column;flex-grow:1;min-width:0;line-height:1.2}.custom-select-label{font-size:.7rem;color:#aaa;white-space:nowrap}body.light-theme .custom-select-label{color:#555}.custom-select-value{font-size:.85rem;font-weight:500;color:var(--text-light);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}body.light-theme .custom-select-value{color:var(--text-dark)}.custom-select-caret{transition:transform .2s ease;color:var(--text-light);font-size:1rem;flex-shrink:0}body.light-theme .custom-select-caret{color:var(--text-dark)}.custom-select-button.is-open .custom-select-caret{transform:rotate(180deg)}.custom-select-list{display:none;position:absolute;top:calc(100% + 4px);left:0;right:0;background-color:#1e1e1eb3;border:1px solid rgba(255,255,255,.15);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-radius:6px;box-shadow:var(--shadow-dark);padding:6px;z-index:1100}#custom-polyhedron-list{right:auto;width:720px;column-count:2;column-gap:6px}#custom-polyhedron-list .custom-select-item{break-inside:avoid;-webkit-column-break-inside:avoid}.custom-select-list.is-open{display:block}body.light-theme .custom-select-list{background-color:#fffc;border:1px solid rgba(0,0,0,.1);box-shadow:var(--shadow-light)}.custom-select-item{padding:10px 12px;border-radius:4px;cursor:pointer;font-size:.9rem;color:var(--text-light);display:flex;align-items:center;gap:12px;transition:background-color .2s,color .2s}body.light-theme .custom-select-item{color:var(--text-dark)}.custom-select-item:hover{background-color:color-mix(in srgb,var(--pill-primary-accent) 22%,transparent);color:var(--pill-primary-accent)}body.light-theme .custom-select-item:hover{color:var(--pill-primary-accent)}.custom-select-item-icon{width:28px;height:28px;background-color:#555;border-radius:4px;flex-shrink:0}body.light-theme .custom-select-item-icon{background-color:#ccc}.tessellate-controls-floater{opacity:0;max-width:0;overflow:hidden;transition:opacity .3s ease,max-width .4s ease-out}.tessellate-controls-floater.visible{opacity:1;max-width:1200px}#tessellate-container{padding:clamp(4px,.4vw,8px) clamp(8px,.9vw,16px);gap:clamp(8px,.8vw,16px);background-color:#2c2c2cb3;border:1px solid rgba(255,255,255,.2);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border-radius:10px;height:auto;min-height:clamp(44px,3.4vw,60px);box-sizing:border-box;display:flex;flex-direction:row;justify-content:flex-start;align-items:center}body.light-theme #tessellate-container{background-color:#ffffffb3;border:1px solid rgba(0,0,0,.1)}#tessellate-container .control-row{display:flex;flex-direction:row;align-items:center;gap:10px;font-size:.75rem}.floater-stepper-btn{width:22px;height:22px;background-color:transparent;border:none;border-radius:0;color:var(--text-light);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:color .2s,background-color .2s;font-size:.95rem;line-height:1;flex-shrink:0;padding:0}body.light-theme .floater-stepper-btn{color:var(--text-dark)}.floater-stepper-btn:hover{color:#fff;background-color:#fff3}body.light-theme .floater-stepper-btn:hover{color:#000;background-color:#0000001a}#tessellate-container .input-group{display:flex;align-items:center;gap:0;border:1px solid rgba(255,255,255,.3);border-radius:6px;background:none;padding:0 6px}body.light-theme #tessellate-container .input-group{border-color:#0003}#tessellate-container label{font-size:.7rem;color:#aaa;flex-shrink:0;padding-right:4px}body.light-theme #tessellate-container label{color:#555}#tessellate-container input[type=number]{width:36px;padding:2px 0;font-size:.75rem;text-align:center;background:none;border:none;color:var(--text-light)}body.light-theme #tessellate-container input[type=number]{color:var(--text-dark)}#tessellate-container .input-group .floater-stepper-btn:first-of-type{border-top-left-radius:4px;border-bottom-left-radius:4px}#tessellate-container .input-group .floater-stepper-btn:last-of-type{border-top-right-radius:4px;border-bottom-right-radius:4px}.hex-button{min-width:clamp(110px,9vw,160px);width:auto;height:clamp(40px,3vw,52px);display:flex;align-items:center;justify-content:flex-start;gap:clamp(8px,.8vw,14px);padding:0 clamp(10px,.8vw,14px) 0 0;font-size:clamp(.7rem,.55vw + .45rem,.9rem);font-weight:500;background:#6b72804d;border:1px solid rgba(255,255,255,.2);backdrop-filter:blur(5px);-webkit-backdrop-filter:blur(5px);border-radius:10px;box-shadow:0 4px 16px #0000004d;cursor:pointer;transition:background-color .3s cubic-bezier(.4,0,.2,1);flex-shrink:0}body.light-theme .hex-button{background:#dcdcdc66;border-color:#0000001a}.hex-button:hover{background:color-mix(in srgb,var(--pill-primary-accent) 22%,transparent);border-color:color-mix(in srgb,var(--pill-primary-accent) 75%,transparent);color:var(--pill-primary-accent);box-shadow:0 0 0 1px color-mix(in srgb,var(--pill-primary-accent) 35%,transparent) inset,0 4px 12px #0000004d}body.light-theme .hex-button:hover{background:color-mix(in srgb,var(--pill-primary-accent) 18%,transparent);border-color:color-mix(in srgb,var(--pill-primary-accent) 55%,transparent);color:var(--pill-primary-accent)}.hex-button:hover .hexagon{background-color:var(--pill-primary-accent)}.hex-button:hover span{color:var(--pill-primary-accent)}.hex-button span{pointer-events:none}.hexagon-wrapper{position:relative;width:25px;height:28.86px;flex-shrink:0}.hexagon{width:25px;height:28.86px;clip-path:polygon(50% 0%,100% 25%,100% 75%,50% 100%,0% 75%,0% 25%);background-color:#fff;position:absolute;top:0;left:0;transform-origin:center;transition-property:transform,opacity;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.6s;transition-delay:0s}body.light-theme .hexagon{background-color:#333}#tessellate-btn .hex-1{transform:scale(1) translateY(0);opacity:1;z-index:10}#tessellate-btn .hex-2,#tessellate-btn .hex-3{transform:scale(.6) translateY(-12px);opacity:0;z-index:5}#tessellate-btn.is-hovering .hex-1{transform:scale(.6) translateY(-12px)}#tessellate-btn.is-hovering .hex-2{transform:scale(.6) translate(-13px,12px);opacity:1}#tessellate-btn.is-hovering .hex-3{transform:scale(.6) translate(13px,12px);opacity:1}#detessellate-btn .hex-1{transform:scale(.6) translateY(-12px);opacity:1;z-index:10}#detessellate-btn .hex-2{transform:scale(.6) translate(-13px,12px);opacity:1;z-index:5}#detessellate-btn .hex-3{transform:scale(.6) translate(13px,12px);opacity:1;z-index:5}#detessellate-btn.is-hovering .hex-1{transform:scale(1) translateY(0)}#detessellate-btn.is-hovering .hex-2,#detessellate-btn.is-hovering .hex-3{transform:scale(.6) translateY(-12px);opacity:0}.hex-button-reverse .hex-1{transform:scale(1) translateY(0);opacity:1;z-index:10}.hex-button-reverse .hex-2,.hex-button-reverse .hex-3{transform:scale(.6) translateY(-12px);opacity:0;z-index:5}@media (max-width: 1024px){.custom-select-container{left:var(--floater-offset-left);top:var(--floater-offset-top)}}@media (max-width: 768px){.custom-select-container{top:calc(var(--container-margin) + var(--app-top-bar-height) + var(--gap));left:10px;width:calc(100% - 20px);max-width:none;flex-direction:column}#custom-tiling-select{width:100%}.tessellate-controls-floater.visible{max-width:100%;margin-top:10px}#tessellate-container{width:100%;height:auto;padding:8px 10px;justify-content:center;flex-direction:row;flex-wrap:wrap;min-height:auto;gap:8px}#tessellate-container .control-row{flex-direction:row;gap:8px;flex-wrap:nowrap;width:100%;justify-content:center}#tessellate-container .input-group{gap:2px}#tessellate-container label{font-size:.75rem}#tessellate-container input[type=number]{width:36px;font-size:.75rem}.hex-button{width:auto;min-width:110px;height:40px;gap:8px;padding:0 12px;font-size:.8rem}.hex-button span{display:inline}.pill-fab-container{left:0;right:0;bottom:10px;transform:none;display:flex;flex-direction:column;align-items:center;padding:0 10px}.frosted-glass-container{width:64px;height:64px;border-radius:32px}.icon-btn{width:46px;height:46px}.frosted-glass-container.expanded-level-1{width:100%;max-width:500px;height:64px;border-radius:32px;padding:0 .4rem;gap:.4rem;justify-content:flex-start;left:auto;right:auto;transform:none}.frosted-glass-container.expanded-level-2{width:100%;max-width:500px;height:auto;min-height:120px;border-radius:20px;flex-wrap:wrap;padding:.4rem;gap:.4rem;justify-content:flex-start;left:auto;right:auto;transform:none}.pill-content{width:0;gap:.2rem}.frosted-glass-container.expanded-level-1 .angle-pill-content,.frosted-glass-container.expanded-level-2 .angle-pill-content{width:calc(100% - 92px - 1.2rem);opacity:1;min-width:0}.frosted-glass-container.expanded-level-2 .distance-pill-content{width:calc(100% - .8rem);opacity:1;justify-content:center;min-width:0}.frosted-glass-container.expanded-level-1 #distanceToggleButton,.frosted-glass-container.expanded-level-2 #distanceToggleButton{width:46px;opacity:1}.angle-icon{width:30px;height:30px}.icon-btn-svg-wrapper{width:36px;height:36px}.pill-content input[type=range]{width:60px;min-width:40px;flex-shrink:1;flex-grow:1}.pill-content input[type=number]{width:38px;font-size:.8rem}.control-btn{width:18px;height:18px;font-size:1rem}#widgetLegend{display:none}.angle-presets-overlay{bottom:85px;width:calc(100% - 40px);max-width:400px}#distance-presets-overlay{width:calc(100% - 40px);max-width:360px}.braid-preset-button{width:100px;height:44px;gap:6px;font-size:.8rem}.braid-preset-button svg{width:34px;height:34px}}.canvas-overlay-buttons{position:absolute;bottom:40px;right:40px;z-index:1001;display:flex;flex-direction:column;gap:15px}.top-right-fabs{position:fixed;top:var(--floater-offset-top);right:var(--container-margin);width:var(--panel-width);height:clamp(54px,calc(3.4vw + 10px),70px);box-sizing:border-box;z-index:1002;display:flex;flex-direction:row;align-items:center;justify-content:space-between;gap:8px;padding:0 clamp(12px,1vw,18px);border-radius:14px;background-color:#4b4b4b14;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(100,100,100,.3);box-shadow:0 8px 24px #0000004d}body.light-theme .top-right-fabs{background-color:#ffffff1a;border-color:#c8c8c833;box-shadow:0 8px 24px #0000001f}.top-right-fabs .icon-btn,.top-right-fabs .download-fab-btn{position:relative;width:clamp(36px,2.8vw,50px);height:clamp(36px,2.8vw,50px);font-size:clamp(.85rem,.5vw + .5rem,1.2rem);border-radius:8px;box-shadow:none}.top-right-fabs .icon-btn:hover,.top-right-fabs .download-fab-btn:hover{transform:none;box-shadow:none}.top-right-fabs .download-fab-container{position:relative;top:auto;right:auto;z-index:auto}.app-top-bar{position:fixed;top:var(--container-margin);left:var(--container-margin);right:var(--container-margin);height:var(--app-top-bar-height);box-sizing:border-box;z-index:1003;display:flex;align-items:center;justify-content:space-between;gap:var(--gap);padding:0 clamp(14px,1.1vw,22px);border-radius:14px;background-color:#2c2c2cb3;border:1px solid rgba(255,255,255,.2);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);box-shadow:0 8px 24px #0000004d}body.light-theme .app-top-bar{background-color:#ffffffb3;border-color:#0000001a;box-shadow:0 8px 24px #0000001f}.app-top-bar-left{display:flex;align-items:center;gap:clamp(14px,1.4vw,28px);min-width:0}.app-brand{font-size:clamp(1.05rem,.9vw + .7rem,1.4rem);font-weight:700;color:var(--pill-primary-accent);letter-spacing:-.01em;white-space:nowrap}body.light-theme .app-brand{color:#924827}.app-tabs{display:flex;align-items:center;gap:clamp(6px,.8vw,16px)}.app-tab{position:relative;display:inline-flex;align-items:center;height:100%;padding:clamp(6px,.5vw,10px) clamp(6px,.5vw,10px);color:var(--pill-primary-accent);opacity:.6;text-decoration:none;font-size:var(--ui-font-size);font-weight:500;letter-spacing:.005em;white-space:nowrap;transition:opacity .15s ease,color .15s ease}.app-tab:hover{opacity:.9}.app-tab.is-active{opacity:1}.app-tab.is-active:after{content:"";position:absolute;left:clamp(6px,.5vw,10px);right:clamp(6px,.5vw,10px);bottom:-2px;height:2px;border-radius:1px;background-color:var(--pill-primary-accent)}body.light-theme .app-tab{color:#924827}body.light-theme .app-tab.is-active:after{background-color:#924827}.app-top-bar>#top-right-fabs,.app-top-bar>#history-fab{position:static;top:auto;right:auto;bottom:auto;left:auto;width:auto;height:100%;padding:0;border:none;background:transparent;box-shadow:none;backdrop-filter:none;-webkit-backdrop-filter:none;flex:0 0 auto;gap:clamp(6px,.6vw,12px)}body.light-theme .app-top-bar>#top-right-fabs,body.light-theme .app-top-bar>#history-fab{background:transparent;border:none;box-shadow:none}@media (max-width: 700px){.app-top-bar{padding:0 10px;gap:8px}.app-top-bar-left{gap:10px}.app-brand{font-size:.95rem}.app-tab{font-size:.85rem;padding:4px 6px}}.download-fab-container{position:fixed;top:calc(var(--floater-offset-top) + 13px);right:24px;z-index:1002;display:flex;flex-direction:column;align-items:flex-end;gap:8px}.download-fab-btn{width:44px;height:44px;border-radius:50%;background-color:#4b4b4b4d;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(100,100,100,.3);box-shadow:0 4px 12px #0000004d;color:var(--pill-button-text);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:16px;padding:0;transition:background-color .2s,transform .1s,color .2s,border-color .2s}body.light-theme .download-fab-btn{background-color:#ffffff80;border-color:#0000001a}.download-fab-btn:hover{background-color:color-mix(in srgb,var(--pill-primary-accent) 22%,transparent);border-color:color-mix(in srgb,var(--pill-primary-accent) 75%,transparent);color:var(--pill-primary-accent);box-shadow:0 0 0 1px color-mix(in srgb,var(--pill-primary-accent) 35%,transparent) inset,0 4px 12px #0000004d;transform:translateY(-1px)}.download-fab-btn:hover i{color:var(--pill-primary-accent)}body.light-theme .download-fab-btn:hover{background-color:#9248271f;border-color:#92482780;color:#924827}.download-fab-btn.is-open{background-color:var(--pill-primary-accent);border-color:var(--pill-primary-accent);color:#000}.download-fab-btn:active{transform:translateY(0) scale(.96)}.download-fab-menu{position:fixed;top:var(--floater-offset-top);right:var(--container-margin);background-color:#4b4b4b4d;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(100,100,100,.3);border-radius:12px;padding:8px;display:flex;flex-direction:column;gap:6px;min-width:110px;opacity:0;visibility:hidden;transform:translateY(-6px);transition:opacity .2s,visibility .2s,transform .2s;z-index:1003}body.light-theme .download-fab-menu{background-color:#fff9;border-color:#0000001a}.download-fab-menu.is-visible{opacity:1;visibility:visible;transform:translateY(0)}.download-fab-menu .panel-btn{margin:0}.download-fab-menu #save-project-fab,.download-fab-menu #load-project-fab,.download-fab-menu #share-link-fab{background-color:color-mix(in srgb,var(--pill-primary-accent) 15%,transparent)!important;color:var(--pill-primary-accent)!important;border-color:color-mix(in srgb,var(--pill-primary-accent) 30%,transparent)!important}.download-fab-menu #save-project-fab:hover,.download-fab-menu #load-project-fab:hover,.download-fab-menu #share-link-fab:hover{background-color:color-mix(in srgb,var(--pill-primary-accent) 30%,transparent)!important;border-color:var(--pill-primary-accent)!important;color:#fff!important}body.light-theme .download-fab-menu #save-project-fab,body.light-theme .download-fab-menu #load-project-fab,body.light-theme .download-fab-menu #share-link-fab{background-color:color-mix(in srgb,var(--pill-primary-accent) 12%,transparent)!important;color:var(--pill-primary-accent)!important;border-color:color-mix(in srgb,var(--pill-primary-accent) 28%,transparent)!important}body.light-theme .download-fab-menu #save-project-fab:hover,body.light-theme .download-fab-menu #load-project-fab:hover,body.light-theme .download-fab-menu #share-link-fab:hover{background-color:color-mix(in srgb,var(--pill-primary-accent) 22%,transparent)!important;color:#fff!important}.download-fab-menu #share-link-fab.is-copied,.download-fab-menu #share-link-fab.is-copied:hover{background-color:#22c55e40!important;border-color:#22c55ecc!important;color:#4ade80!important}.skip-control{display:flex;align-items:center;gap:4px;background:#0009;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:20px;padding:4px 8px;border:1px solid rgba(255,255,255,.15)}.skip-btn{width:26px;height:26px;border-radius:50%;border:1px solid rgba(255,255,255,.2);background:#ffffff14;color:var(--text-light);font-size:14px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}.skip-btn:hover{background:#fff3;border-color:var(--primary-accent)}.skip-value{min-width:18px;text-align:center;font-size:14px;font-weight:700;color:var(--primary-accent);font-family:monospace}body.light-theme .skip-control{background:#fffc;border-color:#00000026}body.light-theme .skip-btn{border-color:#00000026;background:#0000000a;color:var(--text-dark)}body.light-theme .skip-btn:hover{background:#0000001a}.inner-dl-sliders{display:flex;flex-direction:column;gap:4px;margin-top:6px}.inner-dl-row{display:flex;align-items:center;gap:6px;font-size:12px;font-family:monospace}.inner-dl-row .idx{width:22px;color:var(--pill-primary-accent)}.inner-dl-row input[type=range]{flex:1;min-width:0}.inner-dl-row .pct{min-width:36px;text-align:right;color:var(--pill-primary-accent)}.inner-dl-row input[type=range]::-webkit-slider-thumb{background:var(--pill-primary-accent)}.inner-dl-row input[type=range]::-moz-range-thumb{background:var(--pill-primary-accent);border:none}.inner-dl-step-btn{width:22px;height:22px;border-radius:50%;border:1px solid var(--pill-button-border);background:var(--pill-icon-base);color:var(--pill-button-text);font-size:14px;font-weight:600;line-height:1;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;transition:background-color .15s,border-color .15s,transform .1s;padding:0}.inner-dl-step-btn:hover{background:var(--pill-primary-accent);border-color:var(--pill-primary-accent);color:#000}.inner-dl-step-btn:active{transform:scale(.92)}#inner-lines-presets-overlay .inner-dl-num{width:32px;height:22px;text-align:center;border-radius:6px;border:1px solid var(--pill-button-border);background:var(--pill-icon-base);color:var(--pill-button-text);font-size:11px;font-family:inherit;padding:0 2px;flex-shrink:0;-moz-appearance:textfield;-webkit-appearance:textfield;appearance:textfield}#inner-lines-presets-overlay .inner-dl-num::-webkit-outer-spin-button,#inner-lines-presets-overlay .inner-dl-num::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}#inner-lines-presets-overlay .inner-dl-num:focus{outline:none;border-color:var(--pill-primary-accent)}.crosshairs-icon{stroke:var(--pill-primary-accent);stroke-width:3.5;transition:opacity .4s ease-in-out;opacity:1}@media (max-width: 768px){.canvas-overlay-buttons{top:15px;right:15px;bottom:auto;flex-direction:row;gap:10px}}.icon-btn-svg-wrapper{background:transparent;border:1px solid transparent;padding:0;margin:0;cursor:pointer;border-radius:8px;display:flex;align-items:center;justify-content:center;width:48px;height:48px;transition:background-color .2s,border-color .2s,color .2s,transform .1s,box-shadow .2s;flex-shrink:0;color:var(--pill-button-text, #fff)}.icon-btn-svg-wrapper:hover{background:color-mix(in srgb,var(--pill-primary-accent) 22%,transparent);border-color:color-mix(in srgb,var(--pill-primary-accent) 75%,transparent);color:var(--pill-primary-accent);box-shadow:0 0 0 1px color-mix(in srgb,var(--pill-primary-accent) 35%,transparent) inset}.icon-btn-svg-wrapper:hover svg,.icon-btn-svg-wrapper:hover .angle-icon,.icon-btn-svg-wrapper:hover .motif-icon-tinted{color:var(--pill-primary-accent)}.icon-btn-svg-wrapper:active{transform:scale(.96)}body.light-theme .icon-btn-svg-wrapper:hover{background:color-mix(in srgb,var(--pill-primary-accent) 18%,transparent);border-color:color-mix(in srgb,var(--pill-primary-accent) 55%,transparent);color:var(--pill-primary-accent)}.icon-btn-svg-wrapper.active{background:var(--pill-primary-accent);border-color:var(--pill-primary-accent);color:#000;box-shadow:none;transform:translateY(0)}.icon-btn-svg-wrapper.active svg,.icon-btn-svg-wrapper.active .angle-icon{color:#000}.icon-btn-svg-wrapper.active .motif-icon-tinted{background-color:#000!important}body.light-theme .icon-btn-svg-wrapper.active{background:var(--pill-primary-accent);border-color:var(--pill-primary-accent);color:#000}.icon-btn-svg-wrapper .angle-icon{pointer-events:none}.angle-presets-overlay{position:fixed;bottom:calc(var(--gap) + clamp(64px,5.3vw,100px) + var(--gap));left:50%;background-color:#4b4b4b4d;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(100,100,100,.3);box-shadow:0 8px 24px #0000004d;border-radius:12px;padding:10px;display:flex;gap:8px;flex-wrap:wrap;justify-content:center;z-index:1002;opacity:0;visibility:hidden;transform:translate(-50%,10px);transition:opacity .2s ease,visibility .2s ease,transform .2s ease}body.light-theme .angle-presets-overlay{background-color:#ffffff4d;border:1px solid rgba(200,200,200,.3)}.angle-presets-overlay.is-visible{opacity:1;visibility:visible;transform:translate(-50%)}.angle-preset-button{width:44px;height:44px;border-radius:50%;background-color:var(--pill-icon-base);color:var(--pill-button-text);border:1px solid var(--pill-button-border);font-size:.9rem;font-weight:500;cursor:pointer;transition:background-color .2s,transform .1s;display:flex;align-items:center;justify-content:center}.angle-preset-button:hover{background-color:color-mix(in srgb,var(--pill-primary-accent) 22%,transparent);border-color:color-mix(in srgb,var(--pill-primary-accent) 75%,transparent);color:var(--pill-primary-accent)}.angle-preset-button:hover svg{color:var(--pill-primary-accent)}.angle-preset-button.active{background-color:color-mix(in srgb,var(--pill-primary-accent) 15%,transparent);border:1px solid var(--pill-primary-accent);color:var(--pill-primary-accent)}body.light-theme .angle-preset-button.active{color:var(--pill-primary-accent)}.angle-preset-button:active{transform:scale(.95)}.angle-preset-button svg{width:30px;height:30px;opacity:.7;transition:opacity .2s;pointer-events:none}.angle-preset-button:hover svg{opacity:1}.angle-preset-button.active svg{opacity:1}.braid-preset-button{width:130px;height:50px;border-radius:10px;gap:10px;font-size:.9rem;font-weight:500}.braid-preset-button svg{width:44px;height:44px;flex-shrink:0}.braid-preset-button span{pointer-events:none}#distance-presets-overlay{width:360px;align-items:stretch;gap:0;flex-wrap:nowrap}.braid-preset-base,.braid-preset-modifiers{display:flex;flex-direction:column;align-items:center;gap:8px;padding:8px 10px;border-radius:10px;background:#ffffff0a}body.light-theme .braid-preset-base,body.light-theme .braid-preset-modifiers{background:#0000000a}.braid-preset-heading{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:#fff9;text-align:center;padding:0 4px 2px;width:100%;-webkit-user-select:none;user-select:none}body.light-theme .braid-preset-heading{color:#0009}.braid-preset-divider{width:1px;align-self:stretch;background:#ffffff4d;margin:0 10px}body.light-theme .braid-preset-divider{background:#00000040}#motif-presets-overlay{width:auto;min-width:360px;flex-direction:column;align-items:stretch;flex-wrap:nowrap;gap:10px}.motif-row{display:flex;flex-direction:column;gap:6px}.motif-row-head{display:flex;align-items:center;gap:10px}.motif-row-head img,.motif-row-head .motif-row-icon{width:28px;height:28px;flex-shrink:0;pointer-events:none}.motif-row-head .motif-row-icon{display:inline-block;background-color:var(--pill-primary-accent);-webkit-mask-image:var(--motif-mask);mask-image:var(--motif-mask);-webkit-mask-size:contain;mask-size:contain;-webkit-mask-repeat:no-repeat;mask-repeat:no-repeat;-webkit-mask-position:center;mask-position:center}.motif-row-label{color:var(--pill-primary-accent);font-size:.95rem;font-weight:600;min-width:64px;pointer-events:none}.motif-action-btn{height:32px;padding:0 12px;border-radius:8px;background-color:var(--pill-icon-base);color:var(--pill-button-text);border:1px solid var(--pill-button-border);font-size:.85rem;font-weight:500;cursor:pointer;transition:background-color .2s,transform .1s}.motif-action-btn:hover{background-color:color-mix(in srgb,var(--pill-primary-accent) 22%,transparent);border-color:color-mix(in srgb,var(--pill-primary-accent) 75%,transparent);color:var(--pill-primary-accent)}.motif-action-btn:active{transform:scale(.97)}.motif-specific-list{display:flex;flex-wrap:nowrap;gap:6px;width:max-content}.motif-specific-list[hidden]{display:none}.motif-n-btn{min-height:28px;padding:2px 8px;border-radius:5px;background-color:var(--pill-icon-base);color:var(--pill-button-text);border:1px solid var(--pill-button-border);font-size:.7rem;cursor:pointer;transition:background-color .2s,transform .1s;display:inline-flex;flex-direction:column;align-items:center;justify-content:center;gap:0;line-height:1.05;flex-shrink:0;width:auto}.motif-n-btn .n-num{font-weight:600;font-size:.7rem}.motif-n-btn .n-name{font-size:.6rem;opacity:.8}.motif-n-btn:hover{background-color:color-mix(in srgb,var(--pill-primary-accent) 22%,transparent);border-color:color-mix(in srgb,var(--pill-primary-accent) 75%,transparent);color:var(--pill-primary-accent)}.motif-n-btn.active{background-color:var(--pill-primary-accent);border-color:var(--pill-primary-accent);color:#000}#motif-preset-toggle{width:56px;height:56px}#motif-preset-toggle .motif-icon-tinted{display:inline-block;width:36px;height:36px;background-color:var(--pill-primary-accent);-webkit-mask-size:contain;mask-size:contain;-webkit-mask-repeat:no-repeat;mask-repeat:no-repeat;-webkit-mask-position:center;mask-position:center;pointer-events:none;transition:background-color .2s}#inner-lines-presets-overlay{flex-direction:column;align-items:stretch;flex-wrap:nowrap;gap:10px;min-width:280px}.inner-lines-overlay-row{display:flex;align-items:center;justify-content:center;gap:12px}.inner-lines-overlay-label{color:var(--text-light);font-size:.95rem;font-weight:500}#inner-lines-presets-overlay .skip-btn{width:22px;height:22px;border-radius:50%;border:1px solid var(--pill-button-border);background:var(--pill-icon-base);color:var(--pill-button-text);font-size:14px;font-weight:600;line-height:1;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background-color .15s,border-color .15s,transform .1s;padding:0}#inner-lines-presets-overlay .skip-btn:hover{background:var(--pill-primary-accent);border-color:var(--pill-primary-accent);color:#000}#inner-lines-presets-overlay .skip-btn:active{transform:scale(.92)}#inner-lines-presets-overlay .skip-value{min-width:24px;text-align:center;font-size:13px;font-weight:600;color:var(--pill-primary-accent);font-family:inherit}#inner-lines-presets-overlay .inner-dl-sliders{display:flex;flex-direction:column;gap:6px}#toggle-rosette-btn.is-active{background-color:var(--pill-primary-accent);border:2px solid white}#toggle-rosette-btn.is-active text{fill:#000}body.light-theme #toggle-rosette-btn.is-active{background-color:var(--pill-primary-accent);border:2px solid #333}body.light-theme #toggle-rosette-btn.is-active text{fill:#fff}@media (max-width: 400px){.pill-content input[type=range]{width:40px;min-width:30px}.pill-content input[type=number]{width:32px;font-size:.75rem}.icon-btn-svg-wrapper{width:30px;height:30px}.angle-icon{width:26px;height:26px}.control-btn{width:16px;height:16px;font-size:.9rem}#tessellate-container .control-row{gap:5px}#tessellate-container input[type=number]{width:30px}.braid-preset-button{width:80px;height:40px;font-size:.7rem}.braid-preset-button svg{width:28px;height:28px}.angle-preset-button{width:38px;height:38px;font-size:.8rem}.hex-button{min-width:90px;height:36px;font-size:.75rem;gap:5px;padding:0 8px}}.vocab-toggle-btn{width:24px;height:24px;border-radius:6px;border:1px solid rgba(255,255,255,.15);background:#ffffff0f;color:#ffffff59;font-size:11px;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;padding:0;transition:all .2s ease;flex:0 0 24px;-webkit-user-select:none;user-select:none}.vocab-toggle-btn:hover{background:#ffffff1f;border-color:#ffffff4d;color:#fff9}.vocab-toggle-btn.is-active{background:var(--pill-primary-accent, #e8a87c);color:#1a1a2e;border-color:var(--pill-primary-accent, #e8a87c)}.vocab-toggle-btn.is-picking{background:#5b8def;color:#fff;border-color:#5b8def;box-shadow:0 0 0 2px #5b8def40}body.light-theme .vocab-toggle-btn.is-picking{background:#2056d1;color:#fff;border-color:#2056d1}body.light-theme .vocab-toggle-btn{border-color:#00000026;background:#0000000a;color:#0000004d}body.light-theme .vocab-toggle-btn:hover{background:#00000014;color:#00000080}body.light-theme .vocab-toggle-btn.is-active{background:#924827;color:#fff;border-color:#924827}.rosette-menu{position:fixed;z-index:1000;min-width:160px;background:#1c1c26f5;border:1px solid rgba(255,255,255,.12);border-radius:8px;padding:4px;box-shadow:0 8px 24px #0006;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.rosette-menu.is-hidden{display:none}.rosette-menu-item{padding:6px 10px;font-size:12px;color:#ffffffbf;border-radius:5px;cursor:pointer;-webkit-user-select:none;user-select:none;transition:background .15s ease,color .15s ease}.rosette-menu-item:hover{background:#ffffff14;color:#fff}.rosette-menu-item.is-active{background:color-mix(in srgb,var(--pill-primary-accent) 12%,transparent);color:#fffffff2;position:relative;padding-left:14px}.rosette-menu-item.is-active:before{content:"";position:absolute;left:4px;top:50%;transform:translateY(-50%);width:4px;height:60%;border-radius:2px;background:var(--pill-primary-accent)}body.light-theme .rosette-menu-item.is-active{color:#000000f2}.rosette-menu-item.is-disabled{color:#ffffff4d;cursor:not-allowed;font-style:italic}.rosette-menu-item.is-disabled:hover{background:transparent;color:#ffffff4d}.rosette-menu-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:4px 8px 4px 10px;font-size:12px;color:#ffffffd9;-webkit-user-select:none;user-select:none}.rosette-menu-row:hover{background:#ffffff0a;border-radius:5px}.rosette-menu-label{flex:1;white-space:nowrap}.rosette-menu-row .skip-control{gap:6px}.adjust-actions{display:flex;flex-direction:column;gap:6px;align-items:flex-start}.icon-scissors{display:inline-block;width:1.7em;height:1.7em;background-color:currentColor;-webkit-mask:url("data:image/svg+xml,%3c?xml%20version='1.0'%20encoding='utf-8'?%3e%3c!--%20Uploaded%20to:%20SVG%20Repo,%20www.svgrepo.com,%20Generator:%20SVG%20Repo%20Mixer%20Tools%20--%3e%3csvg%20fill='%23ffffff'%20width='32'%20height='32'%20viewBox='0%200%2024%2024'%20version='1.2'%20baseProfile='tiny'%20xmlns='http://www.w3.org/2000/svg'%3e%3cg%20transform='rotate(90%2012%2012)'%3e%3cpath%20d='M20.625%205.515c-1-1.522-2.915-1.67-4.397-.824l-.186.107-.076-.003c-1.042%200-2.01.511-2.604%201.369l-.034.045c-.43.645-.723%201.236-1.005%201.809-.255.516-.5%201.01-.824%201.483-.325-.475-.57-.97-.826-1.486-.283-.571-.575-1.162-1.004-1.806l-.033-.044c-.593-.859-1.562-1.37-2.603-1.37-1.747%200-3.167%201.42-3.167%203.166%200%201.747%201.421%203.168%203.167%203.168.775%200%201.515-.287%202.087-.791l.652%201.198c-1.621%201.876-2.979%204.054-3.019%204.121-1.236%201.702.705%204.42.789%204.534.094.131.245.207.405.207.204-.012.357-.11.439-.261l3.112-5.717%203.113%205.717c.082.15.235.249.407.26.174.019.336-.066.437-.206.083-.114%202.024-2.832.809-4.504l-.323-.521c-1.076-1.736-1.187-1.916-2.715-3.634l.651-1.195c.572.504%201.313.791%202.088.791%201.746%200%203.167-1.421%203.167-3.168%200-.634-.191-1.246-.547-1.768.472-.27.997-.123%201.456.095.466.191.897-.377.584-.772zm-13.625%203.485c-.552%200-1-.447-1-1s.448-1%201-1%201%20.447%201%201-.448%201-1%201zm4.5%203.395c-.277%200-.5-.225-.5-.5%200-.277.223-.5.5-.5s.5.223.5.5c0%20.275-.223.5-.5.5zm4.5-3.395c-.552%200-1-.447-1-1s.448-1%201-1%201%20.447%201%201-.448%201-1%201z'/%3e%3c/g%3e%3c/svg%3e") center / contain no-repeat;mask:url("data:image/svg+xml,%3c?xml%20version='1.0'%20encoding='utf-8'?%3e%3c!--%20Uploaded%20to:%20SVG%20Repo,%20www.svgrepo.com,%20Generator:%20SVG%20Repo%20Mixer%20Tools%20--%3e%3csvg%20fill='%23ffffff'%20width='32'%20height='32'%20viewBox='0%200%2024%2024'%20version='1.2'%20baseProfile='tiny'%20xmlns='http://www.w3.org/2000/svg'%3e%3cg%20transform='rotate(90%2012%2012)'%3e%3cpath%20d='M20.625%205.515c-1-1.522-2.915-1.67-4.397-.824l-.186.107-.076-.003c-1.042%200-2.01.511-2.604%201.369l-.034.045c-.43.645-.723%201.236-1.005%201.809-.255.516-.5%201.01-.824%201.483-.325-.475-.57-.97-.826-1.486-.283-.571-.575-1.162-1.004-1.806l-.033-.044c-.593-.859-1.562-1.37-2.603-1.37-1.747%200-3.167%201.42-3.167%203.166%200%201.747%201.421%203.168%203.167%203.168.775%200%201.515-.287%202.087-.791l.652%201.198c-1.621%201.876-2.979%204.054-3.019%204.121-1.236%201.702.705%204.42.789%204.534.094.131.245.207.405.207.204-.012.357-.11.439-.261l3.112-5.717%203.113%205.717c.082.15.235.249.407.26.174.019.336-.066.437-.206.083-.114%202.024-2.832.809-4.504l-.323-.521c-1.076-1.736-1.187-1.916-2.715-3.634l.651-1.195c.572.504%201.313.791%202.088.791%201.746%200%203.167-1.421%203.167-3.168%200-.634-.191-1.246-.547-1.768.472-.27.997-.123%201.456.095.466.191.897-.377.584-.772zm-13.625%203.485c-.552%200-1-.447-1-1s.448-1%201-1%201%20.447%201%201-.448%201-1%201zm4.5%203.395c-.277%200-.5-.225-.5-.5%200-.277.223-.5.5-.5s.5.223.5.5c0%20.275-.223.5-.5.5zm4.5-3.395c-.552%200-1-.447-1-1s.448-1%201-1%201%20.447%201%201-.448%201-1%201z'/%3e%3c/g%3e%3c/svg%3e") center / contain no-repeat}.adjust-row{position:fixed;top:50%;right:var(--container-margin);transform:translateY(-50%);left:auto;width:auto;height:auto;box-sizing:border-box;padding:clamp(10px,.9vw,16px) clamp(3px,.3vw,6px);border-radius:clamp(24px,2.6vw,38px);background-color:#4b4b4b4d;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(100,100,100,.3);box-shadow:0 8px 24px #0000004d;z-index:1002;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:clamp(6px,.6vw,12px)}body.light-theme .adjust-row{background-color:#ffffff4d;border-color:#c8c8c84d;box-shadow:0 8px 24px #0000001f}.adjust-row .adjust-square{width:clamp(42px,3.6vw,54px);height:auto;border-radius:0;background:transparent;border:none;backdrop-filter:none;-webkit-backdrop-filter:none;transition:none;position:relative;overflow:visible;display:flex;flex-direction:column;align-items:center;gap:2px;padding:2px 0}.adjust-row .adjust-square:hover{background:transparent;border:none;box-shadow:none;transform:none}.adjust-row .adjust-square:active{transform:none}.adjust-row .adjust-square:hover .split-btn-main{background:color-mix(in srgb,var(--pill-primary-accent) 22%,transparent)!important;border:1px solid color-mix(in srgb,var(--pill-primary-accent) 75%,transparent)!important;color:var(--pill-primary-accent)!important;box-shadow:0 0 0 1px color-mix(in srgb,var(--pill-primary-accent) 35%,transparent) inset,0 4px 12px #0000004d!important;transform:translateY(-1px)}.adjust-row .adjust-square:hover .split-btn-main i,.adjust-row .adjust-square:hover .split-btn-main .icon-scissors,.adjust-row .adjust-square:hover .split-btn-main svg{color:var(--pill-primary-accent)!important}.adjust-row .adjust-square:active .split-btn-main{transform:translateY(0) scale(.96)}body.light-theme .adjust-row .adjust-square:hover .split-btn-main{background:#9248271f!important;border:1px solid rgba(146,72,39,.5)!important;color:#924827!important}body.light-theme .adjust-row .adjust-square:hover .split-btn-main i,body.light-theme .adjust-row .adjust-square:hover .split-btn-main .icon-scissors,body.light-theme .adjust-row .adjust-square:hover .split-btn-main svg{color:#924827!important}body.light-theme .adjust-row .adjust-square{background:transparent;border:none}body.light-theme .adjust-row .adjust-square:hover{background:transparent}.adjust-row .adjust-square .split-btn-main{width:clamp(40px,3.4vw,50px)!important;height:clamp(40px,3.4vw,50px)!important;min-width:0!important;max-width:clamp(40px,3.4vw,50px)!important;aspect-ratio:1 / 1;padding:0!important;border:none!important;background:transparent!important;border-radius:8px!important;flex:0 0 auto;color:var(--pill-button-text, #fff);font-size:14px;transition:background-color .2s,color .2s,transform .1s,border-color .2s}.adjust-row .adjust-label{display:none}.adjust-row .adjust-square .split-btn-main i,.adjust-row .adjust-square .split-btn-main .icon-scissors,.adjust-row .adjust-square .split-btn-main svg{font-size:16px;color:#fff!important;fill:currentColor;stroke:currentColor}body.light-theme .adjust-row .adjust-square .split-btn-main i,body.light-theme .adjust-row .adjust-square .split-btn-main .icon-scissors,body.light-theme .adjust-row .adjust-square .split-btn-main svg{color:#111!important}.adjust-row .adjust-square .split-btn-main svg.icon-extend,.adjust-row .adjust-square .split-btn-main svg.icon-trim{width:clamp(22px,1.9vw,28px);height:clamp(22px,1.9vw,28px);fill:none!important;stroke:currentColor}.adjust-row .adjust-square .split-btn-main svg.icon-extend path,.adjust-row .adjust-square .split-btn-main svg.icon-trim path{fill:none!important;stroke:currentColor}.adjust-row .split-btn-group.is-picking .split-btn-main svg.icon-extend,.adjust-row .split-btn-group.is-picking .split-btn-main svg.icon-trim,.adjust-row .split-btn-group.is-picking .split-btn-main svg.icon-extend path,.adjust-row .split-btn-group.is-picking .split-btn-main svg.icon-trim path{fill:none!important;stroke:#000!important}.adjust-row .adjust-square .split-btn-main svg.icon-extend .star-base,.adjust-row .adjust-square .split-btn-main svg.icon-trim .star-base{opacity:1}.adjust-row .adjust-square .split-btn-main svg.icon-extend .star-extended,.adjust-row .adjust-square .split-btn-main svg.icon-trim .star-extended{transform-box:fill-box;transform-origin:center;transition:opacity .45s cubic-bezier(.4,0,.2,1),transform .45s cubic-bezier(.4,0,.2,1)}.adjust-row .adjust-square .split-btn-main svg.icon-extend .star-extended{opacity:0;transform:scale(.6)}.adjust-row .adjust-square .split-btn-main svg.icon-trim .star-extended{opacity:1;transform:scale(1)}.adjust-row .adjust-square:hover .split-btn-main svg.icon-extend .star-extended,.adjust-row .split-btn-group.is-picking .split-btn-main svg.icon-extend .star-extended{opacity:1;transform:scale(1)}.adjust-row .adjust-square:hover .split-btn-main svg.icon-trim .star-extended,.adjust-row .split-btn-group.is-picking .split-btn-main svg.icon-trim .star-extended{opacity:0;transform:scale(.6)}.adjust-row .adjust-square .split-btn-dd.corner{position:absolute!important;top:50%;left:clamp(0px,.1vw,3px);right:auto;width:12px!important;height:12px!important;min-width:0!important;max-width:12px!important;flex:0 0 12px!important;box-sizing:border-box!important;padding:0!important;margin:0!important;outline:none!important;background:transparent!important;background-image:none!important;border:none!important;cursor:pointer;z-index:2;display:flex;align-items:center;justify-content:center;transform:translateY(-50%);opacity:0;transition:opacity .15s ease;pointer-events:auto}.adjust-row .adjust-square .split-btn-dd.corner:focus,.adjust-row .adjust-square .split-btn-dd.corner:focus-visible{outline:none!important;box-shadow:none!important}.adjust-row .adjust-square:hover .split-btn-dd.corner,.adjust-row .adjust-square .split-btn-dd.corner:hover{opacity:1}.adjust-row .adjust-square .split-btn-dd.corner i{font-size:7px;color:#ffffffd9;transform:rotate(90deg);transform-origin:center;margin:0;line-height:1;-webkit-text-stroke:.6px currentColor;text-stroke:.6px currentColor;transition:color .15s ease,-webkit-text-stroke-color .15s ease}.adjust-row .adjust-square .split-btn-dd.corner:hover i{color:#fff}body.light-theme .adjust-row .adjust-square .split-btn-dd.corner i{color:#000000d9}body.light-theme .adjust-row .adjust-square .split-btn-dd.corner:hover i{color:#000}.adjust-row .split-btn-group.is-picking .split-btn-dd.corner i,body.light-theme .adjust-row .split-btn-group.is-picking .split-btn-dd.corner i{color:#000!important}.rosette-menu.adjust-menu{background-color:#4b4b4b4d;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(100,100,100,.3);border-radius:clamp(18px,1.8vw,28px);box-shadow:0 8px 24px #0000004d;padding:clamp(8px,.7vw,12px) clamp(6px,.5vw,10px);min-width:0;display:flex;flex-direction:column;gap:2px}.rosette-menu.adjust-menu.is-hidden{display:none}body.light-theme .rosette-menu.adjust-menu{background-color:#ffffff4d;border-color:#c8c8c84d;box-shadow:0 8px 24px #0000001f}.rosette-menu.adjust-menu .rosette-menu-item{padding:8px 14px;border-radius:12px;font-size:var(--ui-font-size);color:var(--pill-button-text);white-space:nowrap;text-align:left;display:flex;align-items:center;gap:10px}.rosette-menu.adjust-menu .menu-item-icon{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;flex-shrink:0;opacity:.9}.rosette-menu.adjust-menu .menu-item-icon svg{width:16px;height:16px;stroke:currentColor;fill:none}.rosette-menu.adjust-menu .menu-item-icon i{font-size:14px;line-height:1}.rosette-menu.adjust-menu .menu-item-label{flex:1}.rosette-menu.adjust-menu.face-type-menu{border-radius:clamp(14px,1.4vw,22px);padding:clamp(6px,.5vw,9px) clamp(5px,.4vw,8px);gap:1px}.rosette-menu.adjust-menu.face-type-menu .rosette-menu-item{padding:5px 10px;border-radius:9px;font-size:.82rem;gap:7px}.rosette-menu.adjust-menu.face-type-menu .menu-item-icon{width:14px;height:14px;opacity:.85}.rosette-menu.adjust-menu.face-type-menu .menu-item-icon svg{width:14px;height:14px}.rosette-menu.adjust-menu.face-type-menu .face-type-check{display:inline-flex;align-items:center;justify-content:center;width:12px;height:12px;flex-shrink:0;font-size:.78rem;line-height:1;color:var(--pill-primary-accent)}.rosette-menu.adjust-menu.face-type-menu .face-type-count{margin-left:auto;padding-left:8px;opacity:.55;font-size:.7rem;font-variant-numeric:tabular-nums}.rosette-menu.adjust-menu .rosette-menu-item:hover{background:color-mix(in srgb,var(--pill-primary-accent) 22%,transparent);color:var(--pill-primary-accent)}.rosette-menu.adjust-menu .rosette-menu-item.is-active{background:var(--pill-primary-accent);color:#000}body.light-theme .rosette-menu.adjust-menu .rosette-menu-item{color:var(--text-dark)}body.light-theme .rosette-menu.adjust-menu .rosette-menu-item:hover{background:#9248271f;color:#924827}.split-btn-group{display:flex;border-radius:6px;overflow:hidden;border:1px solid rgba(255,255,255,.15);height:36px}.split-btn-main,.split-btn-dd{background:#ffffff0f;color:#ffffffbf;border:none;cursor:pointer;transition:background .15s ease,color .15s ease;display:flex;align-items:center;justify-content:center;padding:0}.split-btn-main{height:36px;padding:0 12px;gap:8px;font-size:13px;font-weight:600;letter-spacing:.2px;min-width:88px}.split-btn-main i{font-size:14px}.split-btn-main span{line-height:1}.split-btn-dd{border-left:1px solid rgba(255,255,255,.15);width:18px;height:36px;flex:0 0 18px;font-size:9px;color:#ffffff80}.split-btn-main:hover,.split-btn-dd:hover{background:#ffffff1f;color:#fff}.split-btn-group.is-picking .split-btn-main{background:#5b8def;color:#fff}.adjust-row .split-btn-group.is-picking .split-btn-main{background:var(--pill-primary-accent)!important;border:1px solid var(--pill-primary-accent)!important;color:#000!important}.adjust-row .split-btn-group.is-picking .split-btn-main i,.adjust-row .split-btn-group.is-picking .split-btn-main .icon-scissors,.adjust-row .split-btn-group.is-picking .split-btn-main svg{color:#000!important;fill:#000!important;stroke:#000!important}body.light-theme .adjust-row .split-btn-group.is-picking .split-btn-main{background:var(--pill-primary-accent)!important;border-color:var(--pill-primary-accent)!important;color:#000!important}body.light-theme .adjust-row .split-btn-group.is-picking .split-btn-main i,body.light-theme .adjust-row .split-btn-group.is-picking .split-btn-main .icon-scissors,body.light-theme .adjust-row .split-btn-group.is-picking .split-btn-main svg{color:#000!important;fill:#000!important;stroke:#000!important}body.light-theme .split-btn-group{border-color:#00000026}body.light-theme .split-btn-main,body.light-theme .split-btn-dd{background:#0000000a;color:#000000b3}body.light-theme .split-btn-main:hover,body.light-theme .split-btn-dd:hover{background:#00000014;color:#000}body.light-theme .split-btn-dd{border-left-color:#00000026}body.light-theme .split-btn-group.is-picking .split-btn-main{background:#2056d1;color:#fff}body.light-theme .rosette-menu-row{color:#000000c7}body.light-theme .rosette-menu-row:hover{background:#0000000a}body.light-theme .rosette-menu{background:#fffffff7;border-color:#0000001a;box-shadow:0 8px 24px #00000026}body.light-theme .rosette-menu-item{color:#000000b3}body.light-theme .rosette-menu-item:hover{background:#0000000f;color:#000}body.light-theme .rosette-menu-item.is-active{background:#924827;color:#fff}body.light-theme .rosette-menu-item.is-disabled{color:#0000004d}.measure-hud{position:fixed;top:24px;left:50%;transform:translate(-50%);z-index:1100;padding:8px 16px;border-radius:10px;background:#141414d9;color:#fff;font-size:14px;font-weight:600;letter-spacing:.02em;box-shadow:0 6px 18px #00000059;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);pointer-events:none;display:flex;align-items:center;gap:8px;white-space:nowrap}.measure-hud.is-hidden{display:none}.measure-hud .hud-label{opacity:.7;font-weight:500}.measure-hud .hud-value{color:var(--pill-primary-accent)}body.light-theme .measure-hud{background:#ffffffe6;color:#111;box-shadow:0 6px 18px #0003}body.light-theme .measure-hud .hud-value{color:#924827}.measure-label{background:#141414d9;color:var(--pill-primary-accent);padding:3px 8px;border-radius:5px;font-size:12px;font-weight:600;font-family:inherit;white-space:nowrap;pointer-events:none;transform:translate(-50%,-50%);box-shadow:0 2px 6px #00000059;border:1px solid color-mix(in srgb,var(--pill-primary-accent) 40%,transparent)}body.light-theme .measure-label{background:#fffffff2;color:#924827;border-color:#92482766;box-shadow:0 2px 6px #0003}.measure-label-editable{cursor:text;pointer-events:auto;-webkit-user-select:none;user-select:none;border-style:dashed}.measure-label-editable:hover{background:color-mix(in srgb,var(--pill-primary-accent) 18%,transparent);color:#ffdac3}body.light-theme .measure-label-editable:hover{background:#9248271f;color:#6b3216}.measure-label-input{width:6ch;background:transparent;border:none;outline:none;color:inherit;font:inherit;text-align:center;padding:0}.measure-label-input::-webkit-outer-spin-button,.measure-label-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.measure-label-input{-moz-appearance:textfield;-webkit-appearance:textfield;appearance:textfield}.face-editor-bar{position:fixed;bottom:16px;left:16px;z-index:1100;padding:10px 14px;border-radius:12px;background:#141414e0;color:#fff;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);box-shadow:0 6px 18px #00000059;display:flex;flex-direction:column;align-items:stretch;gap:10px;font-size:12px;max-width:260px}.face-editor-bar>.face-editor-actions{display:flex;gap:8px}.face-editor-title{color:#ffffffd9}.face-editor-title strong{color:var(--pill-primary-accent);font-weight:600}.face-editor-btn{border:none;border-radius:6px;padding:6px 12px;font-size:12px;font-weight:600;cursor:pointer;transition:background-color .15s ease,transform .05s ease}.face-editor-save{background:var(--pill-primary-accent);color:#1a1a1a}.face-editor-save:hover{background:#ffc1a3}.face-editor-cancel{background:#ffffff1f;color:#fff}.face-editor-cancel:hover{background:#fff3}.face-editor-btn:active{transform:scale(.97)}body.light-theme .face-editor-bar{background:#fffffff2;color:#111}body.light-theme .face-editor-title{color:#000000bf}body.light-theme .face-editor-title strong{color:#924827}body.light-theme .face-editor-cancel{background:#00000014;color:#111}body.light-theme .face-editor-cancel:hover{background:#00000024}.auth-gate{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100000;background:#18181a;display:flex;align-items:center;justify-content:center;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.auth-card{background:#28282af2;border:1px solid rgba(255,255,255,.08);border-radius:14px;padding:32px 28px;width:min(360px,calc(100% - 32px));box-shadow:0 20px 60px #0009;display:flex;flex-direction:column;gap:14px}.auth-title{margin:0;font-size:22px;font-weight:700;color:var(--pill-primary-accent);letter-spacing:.02em}.auth-sub{margin:0;font-size:13px;color:#ffffffa6}.auth-input{background:#1f1f21;border:1px solid rgba(255,255,255,.12);border-radius:8px;padding:10px 12px;color:#fff;font-size:14px;outline:none;transition:border-color .15s ease}.auth-input:focus{border-color:var(--pill-primary-accent)}.auth-submit{background:var(--pill-primary-accent);color:#1a1a1a;border:none;border-radius:8px;padding:10px 12px;font-size:14px;font-weight:600;cursor:pointer;transition:background-color .15s ease,transform .05s ease}.auth-submit:hover{background:#ffc1a3}.auth-submit:active{transform:scale(.98)}.auth-error{margin:0;min-height:16px;font-size:12px;color:#ff7a7a}.auth-card.shake{animation:auth-shake .35s ease}@keyframes auth-shake{0%,to{transform:translate(0)}20%{transform:translate(-8px)}40%{transform:translate(8px)}60%{transform:translate(-5px)}80%{transform:translate(5px)}}.top-toggle{display:inline-flex;align-items:center;gap:clamp(6px,.5vw,10px);cursor:pointer;-webkit-user-select:none;user-select:none;padding:0 clamp(14px,1.1vw,20px);height:clamp(34px,2.6vw,48px);border-radius:8px;background:#6b72804d;border:1px solid rgba(255,255,255,.2);backdrop-filter:blur(5px);-webkit-backdrop-filter:blur(5px);transition:background-color .15s ease,border-color .15s ease;font-size:clamp(.7rem,.55vw + .45rem,.9rem);font-weight:500}.top-toggle:hover{background:#6b728073;border-color:color-mix(in srgb,var(--pill-primary-accent) 60%,transparent)}.top-toggle:has(input:checked){background:color-mix(in srgb,var(--pill-primary-accent) 18%,transparent);border-color:color-mix(in srgb,var(--pill-primary-accent) 75%,transparent);box-shadow:0 0 0 1px color-mix(in srgb,var(--pill-primary-accent) 35%,transparent) inset}.top-toggle:has(input:checked) .top-toggle-label{color:var(--pill-primary-accent);font-weight:600}body.light-theme .top-toggle:has(input:checked){background:#9248271f;border-color:#92482780}body.light-theme .top-toggle:has(input:checked) .top-toggle-label{color:#924827}.top-toggle input{display:none}.top-toggle-track{position:relative;width:40px;height:20px;border-radius:999px;background:#ffffff2e;transition:background-color .15s ease;flex-shrink:0}.top-toggle-knob{position:absolute;top:2px;left:2px;width:16px;height:16px;border-radius:50%;background:#fff;transition:transform .15s ease,background-color .15s ease}.top-toggle input:checked+.top-toggle-track{background:var(--pill-primary-accent)}.top-toggle input:checked+.top-toggle-track .top-toggle-knob{transform:translate(20px);background:#1a1a1a}.top-toggle-label{font-size:inherit;font-weight:500;color:#ffffffe6;letter-spacing:.02em}body.light-theme .top-toggle{background:#ffffffb3;border-color:#0000001a}body.light-theme .top-toggle-track{background:#00000026}body.light-theme .top-toggle-knob{background:#fff}body.light-theme .top-toggle-label{color:#000000d9}.sphere-toggle .sphere-icon-wrap{width:44px;height:44px;flex-shrink:0;align-self:center;position:relative;line-height:0}.sphere-toggle .sphere-icon-canvas{width:44px!important;height:44px!important;display:block;margin:0;padding:0}.hex-button .polyhedron-icon-canvas{width:44px;height:44px;display:block;flex-shrink:0;margin:0;padding:0}.hex-button .hex-button-text{display:inline-flex;flex-direction:column;align-items:flex-start;justify-content:center;line-height:1.15;gap:1px;margin-left:auto}.hex-button .hex-button-label{font-weight:600}.hex-button .truncate-target,.hex-button .detruncate-target{margin-left:0;opacity:.7;font-size:.7em}.dome-toggle .dome-icon-wrap{width:44px;height:44px;flex-shrink:0;align-self:center;position:relative;line-height:0;display:inline-flex;align-items:center;justify-content:center;color:inherit;opacity:.65;transition:opacity .2s ease}.dome-toggle:hover .dome-icon-wrap,.dome-toggle input:checked~.dome-icon-wrap{opacity:1}.dome-toggle .dome-icon{width:28px;height:28px;display:block}.studio-side-panel-floating{position:absolute;top:var(--floater-offset-top);left:var(--container-margin);width:var(--panel-width);height:calc(100vh - var(--floater-offset-top) - var(--container-margin));max-height:calc(100vh - var(--floater-offset-top) - var(--container-margin));padding:16px;box-sizing:border-box;border-radius:20px;border:1px solid rgba(100,100,100,.3);background-color:#4b4b4b14;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);box-shadow:0 8px 24px #0000004d;z-index:100;overflow-y:auto;gap:16px}body.light-theme .studio-side-panel-floating{background-color:#ffffff1a;border-color:#c8c8c833;box-shadow:0 8px 24px #0000001f}.studio-side-panel{color:var(--pill-button-text);display:flex;flex-direction:column;gap:16px}.studio-side-footer{padding:12px;border:1px solid var(--border-color-dark);border-radius:8px;display:flex;justify-content:flex-end;gap:8px}body.light-theme .studio-side-footer{border-color:var(--border-color-light)}.studio-side-header{font-weight:600;font-size:1rem;padding-bottom:8px;border-bottom:1px solid var(--border-color-dark);display:flex;align-items:center;justify-content:space-between}body.light-theme .studio-side-header{border-bottom-color:var(--border-color-light)}.studio-add-btn{width:24px;height:24px;border-radius:4px;border:1px solid rgba(255,255,255,.12);background:#ffffff0a;color:inherit;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;font-size:12px;transition:background .12s,border-color .12s}.studio-add-btn:hover{background:#ffffff1a;border-color:#ffffff38}.studio-add-btn.is-active{background-color:color-mix(in srgb,var(--pill-primary-accent) 25%,transparent);border-color:color-mix(in srgb,var(--pill-primary-accent) 70%,transparent);color:var(--pill-primary-accent)}.studio-side-header-actions{display:inline-flex;gap:6px}.studio-group-list{padding:12px;border:1px solid var(--border-color-dark);border-radius:8px;display:flex;flex-direction:column;gap:6px}body.light-theme .studio-group-list{border-color:var(--border-color-light)}.studio-empty-note{font-size:12px;opacity:.6;line-height:1.4;padding:8px}.studio-group-row{display:grid;grid-template-columns:26px 1fr 26px 26px 26px 26px;align-items:center;gap:4px;padding:6px 8px;border-radius:6px;cursor:pointer;background:transparent;border:1px solid transparent;transition:background .1s,border-color .1s}.studio-group-row:hover{background:#ffffff0a}.studio-group-row.is-active{background-color:color-mix(in srgb,var(--pill-primary-accent) 15%,transparent);border-color:color-mix(in srgb,var(--pill-primary-accent) 45%,transparent)}.studio-row-name{font-size:13px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;padding:2px 4px;display:flex;align-items:center;gap:6px}.studio-row-badge{font-size:10px;opacity:.7;display:inline-flex;align-items:center}.studio-row-name-input{font-size:13px;padding:2px 6px;background:#0006;color:inherit;border:1px solid rgba(255,255,255,.3);border-radius:4px;width:100%;box-sizing:border-box}.studio-row-btn{width:26px;height:26px;border-radius:4px;border:none;background:transparent;color:inherit;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;font-size:12px;opacity:.6;transition:opacity .12s,background .12s}.studio-row-btn:hover{opacity:1;background:#ffffff14}.studio-row-btn:disabled{opacity:.25;cursor:not-allowed}.studio-row-btn:disabled:hover{background:transparent}.studio-row-del:hover:not(:disabled){color:#ff7a7a}.studio-group-wrap{display:flex;flex-direction:column;gap:4px}.studio-group-details{display:flex;flex-direction:column;gap:6px;padding:8px 8px 8px 28px;border-left:2px solid color-mix(in srgb,var(--pill-primary-accent) 35%,transparent);margin-left:8px}.studio-quick-content{display:flex;flex-direction:column;gap:4px}.studio-quick-split{display:grid;grid-template-columns:minmax(100px,auto) 1fr;gap:10px;align-items:start}.studio-quick-col{display:flex;flex-direction:column;gap:4px;min-width:0}.studio-quick-col-header{font-size:11px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;opacity:.7;padding:2px 4px 4px;border-bottom:1px solid var(--border-color-dark)}body.light-theme .studio-quick-col-header{border-bottom-color:var(--border-color-light)}.studio-quick-empty{font-size:12px;opacity:.5;padding:6px 4px;font-style:italic}.studio-mode-grid{display:flex;flex-direction:column;gap:4px}.studio-mode-btn{display:flex;flex-direction:row;align-items:center;justify-content:flex-start;gap:8px;padding:4px 10px;border-radius:6px;background-color:#4b4b4b2e;border:1px solid rgba(100,100,100,.3);color:var(--pill-button-text);cursor:pointer;font-size:12px;min-height:30px;width:100%;transition:background-color .12s,border-color .12s,color .12s}body.light-theme .studio-mode-btn{background-color:#0000000a;border-color:#0000001a}.studio-mode-btn svg{width:18px;height:18px;display:block;flex-shrink:0}.studio-mode-btn span{line-height:1}.studio-mode-btn:hover{background-color:color-mix(in srgb,var(--pill-primary-accent) 18%,transparent);border-color:color-mix(in srgb,var(--pill-primary-accent) 55%,transparent);color:var(--pill-primary-accent)}.studio-mode-btn.is-on{background-color:color-mix(in srgb,var(--pill-primary-accent) 28%,transparent);border-color:var(--pill-primary-accent);color:var(--pill-primary-accent)}.studio-quick-row{display:flex;align-items:center;gap:6px;padding:3px 6px;border-radius:4px;background-color:color-mix(in srgb,var(--pill-primary-accent) 8%,transparent);border:1px solid color-mix(in srgb,var(--pill-primary-accent) 18%,transparent);color:var(--pill-button-text);cursor:pointer;font-size:11.5px;line-height:1.2;min-height:22px;box-sizing:border-box;transition:background-color .12s,border-color .12s,color .12s}.studio-quick-row:hover{background-color:color-mix(in srgb,var(--pill-primary-accent) 20%,transparent);border-color:color-mix(in srgb,var(--pill-primary-accent) 45%,transparent)}.studio-quick-row input[type=checkbox]{width:12px;height:12px;accent-color:var(--pill-primary-accent);margin:0;flex-shrink:0}.studio-quick-action{width:100%;text-align:left;font-weight:500}.studio-side-panel .layer-row{padding:1px 2px;background:none;border:none;font-size:.78rem;gap:6px}.studio-side-panel .layer-items{padding-left:4px;gap:3px;margin-top:0}.studio-side-panel .visibility-toggle{width:18px;height:18px;padding:0;font-size:.8rem}.studio-side-panel .color-swatch{width:14px;height:14px;border-radius:3px}.studio-side-panel .layer-name{font-size:.78rem}.studio-row-expand .fa-chevron-down{transition:transform .15s ease}.studio-quick-col-header{padding:1px 4px 3px}body.studio-compose-mode .custom-select-container,body.studio-compose-mode #ui-container,body.studio-compose-mode #pill-fabContainer,body.studio-compose-mode .canvas-overlay-buttons{display:none!important}body.studio-compose-mode #adjust-row>.split-btn-group:not(#measure-btn-group):not(#studio-move-btn-group):not(#studio-copy-btn-group):not(#studio-mirror-btn-group):not(#rotate-btn-group){display:none!important}body.studio-edit-mode #studio-move-btn-group,body.studio-edit-mode #studio-copy-btn-group,body.studio-edit-mode #studio-mirror-btn-group,body.studio-edit-mode .studio-side-panel-floating{display:none!important}.studio-edit-banner{position:fixed;top:calc(var(--container-margin) + var(--app-top-bar-height) + 12px);left:var(--container-margin);z-index:200;display:inline-flex;align-items:center;gap:10px;padding:8px 14px;border-radius:999px;background-color:color-mix(in srgb,var(--pill-primary-accent) 18%,transparent);border:1px solid color-mix(in srgb,var(--pill-primary-accent) 60%,transparent);color:var(--pill-primary-accent);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);box-shadow:0 6px 20px #0000004d;font-size:13px}body.light-theme .studio-edit-banner{background-color:color-mix(in srgb,var(--pill-primary-accent) 18%,transparent);color:var(--pill-primary-accent)}.studio-edit-banner-label{opacity:.75;font-weight:500}.studio-edit-banner-name{font-weight:600}.studio-edit-scale-control{display:inline-flex;align-items:center;gap:6px;padding:3px 8px;border-radius:999px;background:#ffffff0d;border:1px solid rgba(255,255,255,.15);font-size:12px}.studio-edit-scale-control label{opacity:.7}.studio-edit-scale-control input{width:64px;padding:2px 4px;background:#0000004d;color:inherit;border:1px solid rgba(255,255,255,.2);border-radius:4px;font-size:12px}.studio-edit-done-btn{margin-left:6px;padding:5px 12px;border-radius:999px;border:1px solid rgba(255,255,255,.25);background:#ffffff14;color:inherit;cursor:pointer;font-size:12px;display:inline-flex;align-items:center;gap:6px;transition:background .12s}.studio-edit-done-btn:hover{background:#fff3}.studio-edit-discard-btn{border-color:#e76e5080;background:#e76e5026}.studio-edit-discard-btn:hover{background:#e76e504d;border-color:#e76e50bf}.snap-popover{z-index:1003;padding:8px;border-radius:12px;background-color:#4b4b4b4d;color:#eee;border:1px solid rgba(100,100,100,.3);box-shadow:0 8px 24px #0000004d;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);display:flex;flex-direction:column;gap:4px;min-width:180px;font-size:13px}body.light-theme .snap-popover{background-color:#fff9;color:#222;border-color:#0000001a}.snap-popover-row{display:flex;align-items:center;gap:8px;padding:6px 10px;border-radius:8px;cursor:pointer;background-color:color-mix(in srgb,var(--pill-primary-accent) 12%,transparent);border:1px solid color-mix(in srgb,var(--pill-primary-accent) 25%,transparent);color:var(--pill-primary-accent);transition:background-color .12s,border-color .12s,color .12s}.snap-popover-row:hover{background-color:color-mix(in srgb,var(--pill-primary-accent) 25%,transparent);border-color:var(--pill-primary-accent);color:#fff}body.light-theme .snap-popover-row:hover{color:#fff}.snap-popover-row input[type=checkbox]{width:14px;height:14px;accent-color:var(--pill-primary-accent);margin:0}.snap-popover-all-row{margin-bottom:2px;padding-bottom:8px;border-bottom:1px solid rgba(255,255,255,.08)}body.light-theme .snap-popover-all-row{border-bottom-color:#00000014}.rotate-popover{z-index:1003;padding:14px 18px;border-radius:16px;background-color:#4b4b4b4d;color:#eee;border:1px solid rgba(100,100,100,.3);box-shadow:0 8px 24px #0000004d;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);display:flex;flex-direction:column;align-items:stretch;gap:8px;font-size:13px}.rotate-popover-row{display:flex;align-items:center;gap:10px}.rotate-popover-presets{display:flex;align-items:center;justify-content:center;gap:6px;flex-wrap:wrap}.rotate-popover-preset{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:1px solid color-mix(in srgb,var(--pill-octagon-stroke) 40%,transparent);background:color-mix(in srgb,var(--pill-octagon-stroke) 12%,transparent);color:var(--pill-octagon-stroke);height:22px;padding:0 10px;border-radius:999px;cursor:pointer;font:inherit;font-size:11px;font-weight:600;line-height:1;letter-spacing:.02em;transition:background .12s,border-color .12s,color .12s}.rotate-popover-preset:hover{background:color-mix(in srgb,var(--pill-octagon-stroke) 28%,transparent);border-color:var(--pill-octagon-stroke);color:#fff}body.light-theme .rotate-popover-preset:hover{color:#fff}body.light-theme .rotate-popover{background-color:#fff9;color:#222;border-color:#0000001a}.rotate-popover-label{font-weight:600;opacity:.85;padding-right:4px;line-height:16px;display:inline-flex;align-items:center;height:16px}.rotate-popover .control-btn.rotate-popover-step{width:18px;height:16px;line-height:1;padding:0;font-size:10px;display:inline-flex;align-items:center;justify-content:center;color:inherit;opacity:.85}.rotate-popover .control-btn.rotate-popover-step:hover{opacity:1}.rotate-popover .control-btn.rotate-popover-step i{display:block;line-height:1}.rotate-popover md-slider.rotate-popover-slider{width:220px;flex:0 0 auto;margin:0;--md-slider-tint: var(--pill-octagon-stroke);--md-slider-active-track-color: var(--md-slider-tint);--md-slider-inactive-track-color: rgba(255, 255, 255, .3);--md-slider-active-track-height: 4px;--md-slider-inactive-track-height: 4px;--md-slider-active-track-shape: 2px;--md-slider-inactive-track-shape: 2px;--md-slider-handle-color: var(--md-slider-tint);--md-slider-handle-width: 16px;--md-slider-handle-height: 16px;--md-slider-pressed-handle-color: var(--md-slider-tint);--md-slider-hover-handle-color: var(--md-slider-tint);--md-slider-focus-handle-color: var(--md-slider-tint);--md-slider-state-layer-size: 28px;--md-slider-state-layer-color: var(--md-slider-tint)}body.light-theme .rotate-popover md-slider.rotate-popover-slider{--md-slider-inactive-track-color: rgba(0, 0, 0, .2)}.rotate-popover input[type=number].rotate-popover-num{width:44px;height:22px;text-align:center;border-radius:6px;border:1px solid var(--pill-button-border);background:var(--pill-icon-base);color:var(--pill-button-text);font-size:11px;font-family:inherit;padding:0 2px;margin:0;-moz-appearance:textfield;-webkit-appearance:textfield;appearance:textfield;transition:background-color .2s,border-color .2s;box-sizing:border-box}.rotate-popover input[type=number].rotate-popover-num:focus{outline:none;border-color:var(--pill-primary-accent)}.rotate-popover input[type=number].rotate-popover-num::-webkit-outer-spin-button,.rotate-popover input[type=number].rotate-popover-num::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.rotate-popover-reset{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:1px solid color-mix(in srgb,var(--pill-primary-accent) 35%,transparent);background-color:color-mix(in srgb,var(--pill-primary-accent) 10%,transparent);color:inherit;width:26px;height:26px;border-radius:8px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center}.rotate-popover-reset:hover{background-color:color-mix(in srgb,var(--pill-primary-accent) 25%,transparent);border-color:var(--pill-primary-accent)}.studio-transform-panel{padding:12px;border:1px solid var(--border-color-dark);border-radius:8px;display:flex;flex-direction:column;gap:10px}body.light-theme .studio-transform-panel{border-color:var(--border-color-light)}.studio-transform-header{display:flex;align-items:center;justify-content:space-between;font-weight:600;font-size:1rem;padding-bottom:8px;border-bottom:1px solid var(--border-color-dark)}body.light-theme .studio-transform-header{border-bottom-color:var(--border-color-light)}.studio-transform-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px 8px}.studio-transform-grid label{display:flex;flex-direction:column;font-size:11px;opacity:.7;gap:2px}.studio-transform-grid input{background:#00000059;color:inherit;border:1px solid rgba(255,255,255,.15);border-radius:4px;padding:4px 6px;font-size:12px;width:100%;box-sizing:border-box}.studio-transform-grid input:disabled{opacity:.4;cursor:not-allowed}.studio-transform-grid input:focus{border-color:color-mix(in srgb,var(--pill-primary-accent) 70%,transparent);outline:none}
