:root{--bg:#06060a;--card:#0e0e16;--drawer:#0b0b14;--border:#ffffff0f;--border2:#ffffff1c;--text:#ffffffd9;--text-dim:#ffffff59;--text-faint:#ffffff2e;--text-label:#ffffff38;--hover:#ffffff0b;--active:#ffffff14;--accent:#a855f7;--accent-dim:#a855f71f;--shadow:#0006;--mono:"JetBrains Mono","Fira Code",monospace}:root.light{--bg:#f0f0f5;--card:#fff;--drawer:#f8f9fc;--border:#0000000f;--border2:#0000001f;--text:#0f0f1ed9;--text-dim:#0f0f1e80;--text-faint:#0f0f1e4d;--text-label:#0f0f1e66;--hover:#00000009;--active:#00000012;--accent:#8b2be2;--accent-dim:#8b2be21a;--shadow:#0000001f}*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg);font-family:var(--mono);transition:background .3s}::selection{background:var(--accent);color:#fff}.page{background:var(--bg);min-height:100vh;font-family:var(--mono);justify-content:center;align-items:center;padding:40px 24px;transition:background .3s;display:flex;position:relative}.outer{width:100%;max-width:1200px;box-shadow:0 20px 60px var(--shadow);border-radius:24px;align-items:stretch;display:flex}.settings-drawer{border-radius:24px 0 0 24px;flex-shrink:0;width:0;transition:width .35s cubic-bezier(.4,0,.2,1);overflow:hidden}.settings-drawer.open{width:248px}.drawer-inner{background:var(--drawer);border:.5px solid var(--border);border-right:none;border-radius:24px 0 0 24px;flex-direction:column;width:248px;height:100%;transition:background .3s,border-color .3s;display:flex;overflow:hidden}.drawer-header{border-bottom:.5px solid var(--border);flex-shrink:0;padding:22px 20px 16px}.drawer-header-label{letter-spacing:.24em;text-transform:uppercase;color:var(--text-faint);font-size:8.5px;font-weight:600}.drawer-body{flex:1;padding:8px 0;overflow-y:auto}.drawer-section-label{letter-spacing:.2em;text-transform:uppercase;color:var(--text-faint);padding:14px 18px 5px;font-size:8px;font-weight:600}.drawer-tab{cursor:pointer;border-radius:10px;align-items:center;gap:12px;margin:2px 8px;padding:11px 14px 11px 16px;transition:background .15s;display:flex;position:relative}.drawer-tab:hover{background:var(--hover)}.drawer-tab.active{background:var(--active)}.drawer-tab.active:before{content:"";background:var(--accent);border-radius:0 2px 2px 0;width:3px;height:55%;transition:background .3s;position:absolute;top:50%;left:0;transform:translateY(-50%)}.drawer-tab-icon{background:var(--hover);border:.5px solid var(--border2);border-radius:9px;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;transition:all .2s;display:flex}.drawer-tab.active .drawer-tab-icon{background:var(--accent-dim);border-color:var(--accent);opacity:.8}.drawer-tab-icon svg{fill:none;width:15px;height:15px;stroke:var(--text-dim);stroke-width:1.8px;stroke-linecap:round;stroke-linejoin:round;transition:stroke .2s}.drawer-tab.active .drawer-tab-icon svg{stroke:var(--accent)}.drawer-tab-text{flex:1;min-width:0}.drawer-tab-label{letter-spacing:.06em;color:var(--text-dim);font-size:11px;line-height:1.3;transition:color .15s}.drawer-tab.active .drawer-tab-label{color:var(--text)}.drawer-tab-sub{color:var(--text-faint);letter-spacing:.05em;margin-top:2px;font-size:9px;transition:color .15s}.drawer-tab.active .drawer-tab-sub{color:var(--accent);opacity:.8}.drawer-tab-arr{opacity:0;flex-shrink:0;width:14px;height:14px;transition:opacity .15s,transform .15s}.drawer-tab-arr svg{fill:none;width:14px;height:14px;stroke:var(--text-faint);stroke-width:1.5px;stroke-linecap:round;stroke-linejoin:round}.drawer-tab:hover .drawer-tab-arr{opacity:1;transform:translate(2px)}.wrap{background:var(--card);border:.5px solid var(--border);border-radius:24px;flex-direction:column;flex:1;min-width:0;padding:44px;transition:border-radius .35s,background .3s,border-color .3s;display:flex;position:relative}.wrap.drawer-open{border-radius:0 24px 24px 0}.top-bar{flex-shrink:0;justify-content:space-between;align-items:center;margin-bottom:36px;display:flex}.title-container{align-items:center;gap:8px;display:flex}.title-prefix{letter-spacing:.2em;color:var(--text-faint);text-transform:uppercase;-webkit-user-select:none;user-select:none;font-size:11px;font-weight:500}.palette-name-input{letter-spacing:.2em;color:var(--text);text-transform:uppercase;font-size:11px;font-weight:500;font-family:var(--mono);background:0 0;border:1px dashed #0000;border-radius:4px;outline:none;width:140px;padding:4px 6px;transition:all .2s}.palette-name-input:hover{border-color:var(--border2);background:var(--hover)}.palette-name-input:focus{border-color:var(--accent);background:var(--active)}.actions{align-items:center;gap:8px;display:flex}.btn{letter-spacing:.1em;color:var(--text-dim);background:var(--hover);border:.5px solid var(--border2);cursor:pointer;font-size:11px;font-family:var(--mono);border-radius:6px;padding:7px 14px;transition:all .15s}.btn:hover{background:var(--active);color:var(--text)}.btn.active{background:var(--active);color:var(--text);border-color:var(--border2)}.btn-icon{padding:7px 10px}.btn-icon svg{fill:none;stroke:currentColor;stroke-width:1.8px;stroke-linecap:round;stroke-linejoin:round;width:14px;height:14px;display:block}.view-container{flex-direction:column;flex:1;display:flex}.view-section{flex-direction:column;flex:1;animation:.3s fadeIn;display:none}.view-section.active{display:flex}@keyframes fadeIn{0%{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}.swatches{gap:4px;height:242px;margin-bottom:32px;display:flex;position:relative}.swatch{cursor:pointer;-webkit-user-select:none;user-select:none;border-radius:12px;flex-direction:column;flex:1;justify-content:space-between;padding:10px 8px;transition:flex .25s,border-radius .2s;display:flex;position:relative;overflow:hidden}.swatch:hover{border-radius:16px;flex:2.6}.swatch:hover .swatch-top,.swatch:hover .swatch-label{opacity:1;transform:translateY(0)}.swatch-top{opacity:0;justify-content:flex-end;align-items:flex-start;transition:opacity .2s,transform .2s;display:flex;transform:translateY(-4px)}.swatch-icons{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:5px;display:flex}.swatch-icon{cursor:pointer;background:#00000061;border:.5px solid #ffffff38;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;width:26px;height:26px;transition:background .15s;display:flex}.swatch-icon:hover{background:#0009}.swatch-icon svg{fill:none;stroke:#fff;stroke-width:1.8px;stroke-linecap:round;stroke-linejoin:round;width:13px;height:13px}.swatch-icon.delete-icon:hover{background:#dc3232a6}.lock-icon.locked svg{stroke:var(--accent)}.drag-handle{cursor:grab}.drag-handle:active{cursor:grabbing}.swatch-label{opacity:0;pointer-events:auto;transition:all .2s;transform:translateY(6px)}.swatch-hex-lbl{letter-spacing:.05em;font-size:10px;font-weight:500}.swatch-name-input{letter-spacing:.14em;text-transform:uppercase;opacity:.85;font-size:9px;font-family:var(--mono);width:100%;color:inherit;background:0 0;border:1px dashed #0000;border-radius:3px;outline:none;margin-top:3px;padding:2px 4px;transition:background .2s,border-color .2s;display:block}.swatch-name-input:hover{background:#0000001a;border-color:#ffffff4d}.swatch-name-input:focus{opacity:1;background:#0003;border-color:#fff9}.lock-badge{opacity:.6;width:18px;height:18px;position:absolute;bottom:10px;right:10px}.lock-badge svg{fill:none;stroke:#fff;stroke-width:2px;stroke-linecap:round;stroke-linejoin:round;width:18px;height:18px}.drop-line{background:var(--accent);pointer-events:none;z-index:10;border-radius:2px;width:3px;display:none;position:absolute;top:0;bottom:0}.copy-check{border-radius:inherit;pointer-events:none;opacity:0;justify-content:center;align-items:center;transition:opacity .15s;display:flex;position:absolute;inset:0;overflow:visible}.copy-check svg{filter:drop-shadow(0 0 6px #00000080);width:48px;height:48px;overflow:visible}.check-circle{stroke-dasharray:100;stroke-dashoffset:100px;transition:stroke-dashoffset .35s}.check-tick{stroke-dasharray:50;stroke-dashoffset:50px;transition:stroke-dashoffset .3s .2s}.copy-check.show{opacity:1}.copy-check.show .check-circle,.copy-check.show .check-tick{stroke-dashoffset:0}.add-swatch-btn{border:1.5px dashed var(--border2);cursor:pointer;opacity:.45;background:0 0;border-radius:12px;flex-shrink:0;justify-content:center;align-self:stretch;align-items:center;width:34px;transition:all .2s;display:flex}.add-swatch-btn:hover{opacity:1;border-color:var(--accent);background:var(--accent-dim)}.add-swatch-btn svg{fill:none;width:16px;height:16px;stroke:var(--text-dim);stroke-width:2px;stroke-linecap:round}.add-swatch-btn:hover svg{stroke:var(--accent)}.info-row{grid-template-columns:1fr 1fr 1fr;gap:12px;margin-bottom:24px;display:grid}.info-card{background:var(--hover);border:.5px solid var(--border);border-radius:12px;padding:14px 16px;transition:border-color .3s}.info-card:hover{border-color:var(--accent-dim)}.info-label{letter-spacing:.18em;text-transform:uppercase;color:var(--text-faint);margin-bottom:8px;font-size:9px}.info-value{color:var(--text);font-size:15px;font-weight:500}.preview-row{align-items:stretch;gap:12px;display:flex}.preview-ui{background:var(--hover);border:.5px solid var(--border);border-radius:12px;flex-direction:column;flex:1;gap:10px;padding:16px;display:flex}.preview-label{letter-spacing:.18em;text-transform:uppercase;color:var(--text-faint);margin-bottom:4px;font-size:9px}.ui-bar{border-radius:4px;height:7px}.ui-dot-row{align-items:center;gap:8px;display:flex}.ui-dot{border-radius:50%;flex-shrink:0;width:26px;height:26px}.ui-pill{border-radius:11px;flex:1;height:22px}.ui-text-line{border-radius:3px;height:6px}.gradient-strip{background:var(--hover);border:.5px solid var(--border);border-radius:12px;flex-direction:column;flex:0 0 52px;gap:3px;padding:3px;display:flex;overflow:hidden}.grad-block{border-radius:7px;flex:1}.viz-grid{grid-template-rows:1fr 1fr;grid-template-columns:1fr 1fr;gap:16px;height:100%;min-height:400px;display:grid}.viz-card{background:var(--hover);border:.5px solid var(--border);border-radius:16px;flex-direction:column;padding:16px;display:flex;position:relative;overflow:hidden}.viz-title{letter-spacing:.18em;text-transform:uppercase;color:var(--text-faint);flex-shrink:0;margin-bottom:12px;font-size:9px}.viz-content{border-radius:8px;flex:1;position:relative;overflow:hidden}.viz-footer{letter-spacing:.18em;text-transform:uppercase;color:var(--text-faint);text-align:right;flex-shrink:0;margin-top:12px;font-size:9px}.viz-dl-btn{background:var(--active);border:.5px solid var(--border2);cursor:pointer;opacity:0;z-index:10;border-radius:8px;justify-content:center;align-items:center;width:30px;height:30px;transition:all .2s;display:flex;position:absolute;top:12px;right:12px;transform:translateY(-4px)}.viz-card:hover .viz-dl-btn{opacity:1;transform:translateY(0)}.viz-dl-btn:hover{background:var(--accent);border-color:var(--accent)}.viz-dl-btn svg{fill:none;width:14px;height:14px;stroke:var(--text);stroke-width:2px;stroke-linecap:round}.viz-dl-btn:hover svg{stroke:#fff}.viz-geo{isolation:isolate;justify-content:center;align-items:center;height:100%;display:flex}.viz-geo-shape{mix-blend-mode:hard-light;border-radius:50%;width:60px;height:60px;margin:0 -15px;box-shadow:0 4px 14px #00000059}.viz-type{height:100%;padding:0;display:flex;overflow:hidden}.vt-left{flex-direction:column;flex:1;justify-content:space-between;min-width:0;padding:20px 22px;display:flex;overflow:hidden}.vt-eyebrow{letter-spacing:.22em;text-transform:uppercase;opacity:.75;font-size:9px;font-weight:600;font-family:var(--mono);margin-bottom:10px}.vt-heading{letter-spacing:-1.5px;margin-bottom:10px;font-family:Orbitron,sans-serif;font-size:28px;font-weight:900;line-height:1.05}.vt-body{opacity:.6;font-family:Orbitron,sans-serif;font-size:12px;line-height:1.65}.vt-btn{letter-spacing:.12em;text-transform:uppercase;font-size:9px;font-weight:700;font-family:var(--mono);white-space:nowrap;border-radius:20px;align-items:center;padding:7px 16px;display:inline-flex}.vt-swatches{flex-direction:column;flex-shrink:0;width:28px;display:flex}.vt-swatch{flex:1}.vt-swatch:first-child{border-radius:0 8px 0 0}.vt-swatch:last-child{border-radius:0 0 8px}.viz-depth{perspective:800px;justify-content:center;align-items:center;height:100%;padding:20px;display:flex;position:relative}.depth-card{border-radius:12px;width:100px;height:140px;position:absolute;box-shadow:-10px 10px 20px #0000004d}.viz-flow{width:100%;height:100%}.editor-popup{background:var(--drawer);border:.5px solid var(--border2);z-index:100;width:260px;box-shadow:0 8px 40px var(--shadow);border-radius:14px;padding:18px;display:none;position:absolute}.editor-popup.open{display:block}.editor-title{letter-spacing:.18em;text-transform:uppercase;color:var(--text-faint);margin-bottom:14px;font-size:9px}.editor-preview{border:.5px solid var(--border2);border-radius:8px;width:100%;height:48px;margin-bottom:14px}.editor-tabs{gap:4px;margin-bottom:14px;display:flex}.editor-tab{letter-spacing:.1em;text-transform:uppercase;text-align:center;cursor:pointer;color:var(--text-faint);border:.5px solid #0000;border-radius:6px;flex:1;padding:5px 0;font-size:10px;transition:all .15s}.editor-tab.active{color:var(--text);background:var(--active);border-color:var(--border2)}.editor-fields{flex-direction:column;gap:8px;display:flex}.editor-field{align-items:center;gap:8px;display:flex}.editor-field label{letter-spacing:.1em;color:var(--text-faint);text-transform:uppercase;width:20px;font-size:9px}.editor-field input[type=text]{background:var(--hover);border:.5px solid var(--border2);color:var(--text);font-size:12px;font-family:var(--mono);border-radius:6px;outline:none;flex:1;padding:5px 8px}.editor-field input[type=text]:focus{border-color:var(--accent)}.editor-field input[type=range]{height:4px;accent-color:var(--accent);flex:1}.editor-apply{letter-spacing:.12em;text-transform:uppercase;width:100%;color:var(--text);background:var(--active);border:.5px solid var(--border2);cursor:pointer;font-size:10px;font-family:var(--mono);border-radius:8px;margin-top:12px;padding:8px;transition:all .15s}.editor-apply:hover{background:var(--accent-dim);border-color:var(--accent)}.export-popup{background:var(--drawer);border:.5px solid var(--border2);z-index:200;width:230px;box-shadow:0 8px 40px var(--shadow);border-radius:14px;padding:8px;display:none;position:absolute;top:60px;right:44px}.export-popup.open{display:block}.export-section-lbl{letter-spacing:.2em;text-transform:uppercase;color:var(--text-faint);padding:8px 10px 4px;font-size:8px;font-weight:600}.export-divider{background:var(--border);height:.5px;margin:5px 2px}.export-opt{cursor:pointer;border-radius:8px;align-items:center;gap:10px;padding:9px 10px;transition:background .15s;display:flex}.export-opt:hover{background:var(--hover)}.export-opt-icon{background:var(--hover);border:.5px solid var(--border);border-radius:7px;flex-shrink:0;justify-content:center;align-items:center;width:30px;height:30px;display:flex}.export-opt-icon svg{fill:none;width:14px;height:14px;stroke:var(--text-dim);stroke-width:1.7px;stroke-linecap:round;stroke-linejoin:round}.export-opt-info{flex:1}.export-opt-label{color:var(--text-dim);letter-spacing:.06em;font-size:11px}.export-opt-sub{color:var(--text-faint);letter-spacing:.03em;margin-top:1px;font-size:9px}.theme-toggle{background:var(--active);border:.5px solid var(--border2);cursor:pointer;z-index:600;border-radius:15px;align-items:center;width:54px;height:30px;padding:4px;transition:background .3s,border-color .3s;display:flex;position:fixed;bottom:24px;right:24px}.toggle-knob{background:var(--text-dim);border-radius:11px;flex-shrink:0;justify-content:center;align-items:center;width:22px;height:22px;transition:transform .3s cubic-bezier(.4,0,.2,1),background .3s;display:flex}:root.light .toggle-knob{background:var(--accent);transform:translate(24px)}.toggle-knob svg{fill:none;stroke:#fff;stroke-width:2px;stroke-linecap:round;stroke-linejoin:round;width:12px;height:12px}.icon-sun{display:none}.icon-moon,:root.light .icon-sun{display:block}:root.light .icon-moon{display:none}.modal-backdrop{-webkit-backdrop-filter:blur(6px);z-index:500;opacity:0;pointer-events:none;background:#000000b3;justify-content:center;align-items:center;transition:opacity .2s;display:flex;position:fixed;inset:0}.modal-backdrop.open{opacity:1;pointer-events:auto}.modal-card{background:var(--drawer);border:.5px solid var(--border2);width:440px;max-width:calc(100vw - 48px);box-shadow:0 24px 80px var(--shadow);border-radius:20px;padding:28px;transition:transform .25s cubic-bezier(.4,0,.2,1),background .3s;position:relative;transform:translateY(10px)}.modal-backdrop.open .modal-card{transform:translateY(0)}.modal-title{color:var(--text);letter-spacing:.06em;margin-bottom:20px;font-size:13px;font-weight:500}.modal-close{background:var(--hover);border:.5px solid var(--border2);cursor:pointer;border-radius:7px;justify-content:center;align-items:center;width:28px;height:28px;transition:background .15s;display:flex;position:absolute;top:16px;right:16px}.modal-close:hover{background:var(--active)}.modal-close svg{fill:none;width:12px;height:12px;stroke:var(--text-dim);stroke-width:2px;stroke-linecap:round}.img-drop{border:1.5px dashed var(--border2);text-align:center;cursor:pointer;border-radius:12px;padding:36px 20px;transition:all .15s;position:relative}.img-drop:hover,.img-drop.dragover{border-color:var(--accent);background:var(--accent-dim)}.img-drop input{opacity:0;cursor:pointer;width:100%;height:100%;position:absolute;inset:0}.img-drop-icon{fill:none;width:40px;height:40px;stroke:var(--text-faint);stroke-width:1.4px;stroke-linecap:round;stroke-linejoin:round;margin:0 auto 12px;display:block}.img-drop-text{color:var(--text-faint);letter-spacing:.05em;font-size:12px}.img-drop-hint{color:var(--text-faint);opacity:.55;letter-spacing:.04em;margin-top:5px;font-size:10px}.img-preview-thumb{object-fit:cover;border:.5px solid var(--border);border-radius:10px;width:100%;height:120px;margin-top:14px;display:none}.img-extract-btn{letter-spacing:.12em;text-transform:uppercase;width:100%;color:var(--text);background:var(--accent-dim);cursor:pointer;font-size:10px;font-family:var(--mono);border:.5px solid #a855f74d;border-radius:10px;margin-top:12px;padding:11px;transition:background .15s;display:none}.img-extract-btn:hover{background:var(--accent-dim);border-color:var(--accent)}.img-status{color:var(--accent);text-align:center;letter-spacing:.06em;min-height:16px;margin-top:8px;font-size:10px}.swatch-color-name{letter-spacing:.06em;text-transform:uppercase;white-space:nowrap;text-overflow:ellipsis;max-width:100%;margin-top:2px;font-size:9px;transition:opacity .2s;overflow:hidden}.swatch:hover .swatch-color-name{opacity:.8!important}.img-mode-tabs{background:var(--hover);border-radius:10px;gap:4px;margin-bottom:14px;padding:3px;display:flex}.img-mode-tab{letter-spacing:.14em;text-transform:uppercase;text-align:center;cursor:pointer;color:var(--text-faint);font-size:9px;font-family:var(--mono);border-radius:7px;flex:1;padding:8px 0;transition:all .15s}.img-mode-tab.active{color:var(--text);background:var(--active);border:.5px solid var(--border2)}.img-picker-area{aspect-ratio:16/9;cursor:default;background:#000;border-radius:12px;margin-bottom:14px;position:relative;overflow:hidden}.img-picker-canvas{width:100%;height:100%;position:absolute;inset:0}.img-picker-hint{letter-spacing:.1em;text-transform:uppercase;color:#ffffff8c;pointer-events:none;white-space:nowrap;background:#0009;border-radius:6px;padding:4px 10px;font-size:9px;position:absolute;bottom:8px;left:50%;transform:translate(-50%)}.img-loupe{pointer-events:none;z-index:10;border:2px solid #ffffffbf;border-radius:50%;width:80px;height:80px;position:absolute;overflow:hidden;box-shadow:0 4px 16px #00000080}.img-loupe canvas{width:80px;height:80px;display:block}.img-loupe-crosshair{pointer-events:none;position:absolute;inset:0}.img-loupe-crosshair:before,.img-loupe-crosshair:after{content:"";background:#fff9;position:absolute}.img-loupe-crosshair:before{width:1px;height:100%;left:50%;transform:translate(-50%)}.img-loupe-crosshair:after{width:100%;height:1px;top:50%;transform:translateY(-50%)}.img-count-row{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.img-count-badge{letter-spacing:.1em;text-transform:uppercase;color:var(--text-faint);font-size:9px}.img-count-badge span{color:var(--accent)}.img-clear-btn{letter-spacing:.1em;text-transform:uppercase;color:var(--text-faint);cursor:pointer;font-size:9px;font-family:var(--mono);background:0 0;border:none;transition:color .15s}.img-clear-btn:hover{color:var(--text)}.img-selected-strip{background:var(--hover);border:.5px solid var(--border);border-radius:10px;flex-wrap:wrap;gap:6px;min-height:40px;margin-bottom:14px;padding:6px;display:flex}.strip-empty{letter-spacing:.1em;text-transform:uppercase;color:var(--text-faint);align-self:center;padding:4px 6px;font-size:9px}.sel-chip{cursor:pointer;border-radius:8px;flex-shrink:0;width:36px;height:36px;transition:transform .1s;position:relative}.sel-chip:hover{transform:scale(1.1)}.sel-chip-x{opacity:0;background:#00000080;border-radius:8px;justify-content:center;align-items:center;transition:opacity .15s;display:flex;position:absolute;inset:0}.sel-chip:hover .sel-chip-x{opacity:1}.img-extract-btn:disabled{opacity:.35;cursor:not-allowed}
