body,html{margin:0;padding:0;font-family:Figtree,-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;height:100%;overflow:hidden}.skip-link{position:absolute;top:-40px;left:6px;background:#000;color:#fff;padding:8px;text-decoration:none;border-radius:4px;z-index:10000;font-size:14px}.skip-link:focus{top:6px}button,input,select,textarea{font-family:inherit}#gradient-canvas{--gradient-color-1:#a8e6fc;--gradient-color-2:#6bb6ff;--gradient-color-3:#a78bfa;--gradient-color-4:#f5a8d6}.loading-screen{position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,.2);display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:2000;color:rgba(255,255,255,.9);font-family:inherit;opacity:1;transition:opacity .5s ease-in-out}.loading-screen.fade-out{opacity:0}.loading-spinner{width:50px;height:50px;border:3px solid rgba(255,255,255,.2);border-top:3px solid #fff;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:20px}@keyframes spin{0%{transform:rotate(0)}100%{transform:rotate(360deg)}}.loading-text{font-size:18px;font-weight:500;text-align:center;font-family:inherit}.controls{position:fixed;top:0;right:-380px;z-index:1000;background:rgba(0,0,0,.7);backdrop-filter:blur(10px);border-radius:12px 0 0 12px;padding:20px;color:#fff;width:340px;height:100vh;transition:right .3s ease-in-out;box-shadow:0 8px 32px rgba(0,0,0,.3);border:1px solid rgba(255,255,255,.1);box-sizing:border-box;overflow:auto}.controls.open{right:0}.controls.open{right:0}.controls-toggle{position:fixed;top:0;width:50px;height:50px;color:#fff;font-size:20px;cursor:pointer;z-index:1001;transition:right .3s ease-in-out;display:flex;align-items:center;justify-content:center;background:0 0;border:none;right:-30px}.controls-toggle.closed{color:transparent;right:-30px;background:rgba(0,0,0,.7);border-radius:12px 0 0 12px;box-shadow:0 8px 32px rgba(0,0,0,.3);backdrop-filter:blur(10px)}.controls-toggle.active{right:290px}.toggle-icon{transition:transform .3s ease;display:inline-block}.controls header{text-align:center;margin-bottom:20px}.controls h1{margin:22px 0 8px 0;font-size:18px;font-weight:600;line-height:1.2}.controls .subtitle{margin:0 0 12px 0;font-size:14px;color:#aaa;font-weight:400}.control-group{margin-bottom:15px}.control-group label{display:block;margin-bottom:8px;font-size:14px;font-weight:500}.shader-select{width:100%;padding:10px;border-radius:8px;border:1px solid #444;background:#222;color:#fff;font-size:14px;cursor:pointer;background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%23ffffff' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='m6 8 4 4 4-4'/%3e%3c/svg%3e");background-position:right 5px center;background-repeat:no-repeat;background-size:16px;appearance:none;-webkit-appearance:none;-moz-appearance:none}.shader-select:focus{outline:0;border-color:#6ec3f4;box-shadow:0 0 0 2px rgba(110,195,244,.2)}.shader-description{margin-top:8px;font-size:12px;color:#999;line-height:1.4;word-wrap:break-word;overflow-wrap:break-word}.control-buttons{display:flex;gap:10px;margin-top:15px}.btn{padding:8px 16px;border:none;border-radius:6px;background:#6ec3f4;color:#fff;font-size:12px;font-weight:500;cursor:pointer;transition:background .2s}.btn:hover{background:#5ba8d4}.btn.secondary{background:#444}.btn.secondary:hover{background:#555}.btn.disabled{opacity:.5;cursor:not-allowed;pointer-events:none}.btn.primary-cta{background:linear-gradient(135deg,#6ec3f4 0,#5ba8d4 100%);font-size:16px;font-weight:600;padding:14px 24px;width:100%;margin:12px 0 12px 0;box-shadow:0 4px 16px rgba(110,195,244,.3);border:1px solid rgba(110,195,244,.4);position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center}.btn.primary-cta:hover{background:linear-gradient(135deg,#5ba8d4 0,#4a90b8 100%);box-shadow:0 6px 20px rgba(110,195,244,.4);transform:translateY(-1px)}.btn.primary-cta:active{transform:translateY(0);box-shadow:0 2px 8px rgba(110,195,244,.3)}.button-group{display:flex;gap:8px;margin:8px 0}.button-group .btn{flex:1;margin:0}.download-section{padding-top:20px;margin-top:20px;border-top:1px solid rgba(255,255,255,.2);display:flex;flex-direction:column;justify-content:center}.dimension-controls{margin:12px 0}.dimension-row{display:flex;gap:12px;margin-bottom:12px}.dimension-item{flex:1;display:flex;flex-direction:column;gap:4px}.dimension-item label{font-size:12px;color:#aaa;font-weight:500}.dimension-item input[type=number]{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);border-radius:6px;padding:8px 10px;color:#fff;font-size:14px;font-weight:500;text-align:center}.dimension-item input[type=number]:focus{outline:0;border-color:#6ec3f4;box-shadow:0 0 0 2px rgba(110,195,244,.2)}.format-select{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);border-radius:6px;padding:8px 10px;color:#fff;font-size:14px;font-weight:500;cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%23ccc' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3e%3c/svg%3e");background-position:right 8px center;background-repeat:no-repeat;background-size:16px;padding-right:32px}.format-select:focus{outline:0;border-color:#6ec3f4;box-shadow:0 0 0 2px rgba(110,195,244,.2)}.format-select option{background:#333;color:#fff}.dimension-presets{margin-bottom:12px}.preset-scroll{display:flex;gap:8px;overflow-x:auto;padding:4px 0 8px 0;scrollbar-width:thin;scrollbar-color:#444 transparent}.preset-scroll::-webkit-scrollbar{height:4px}.preset-scroll::-webkit-scrollbar-track{background:0 0}.preset-scroll::-webkit-scrollbar-thumb{background:#444;border-radius:2px}.preset-scroll::-webkit-scrollbar-thumb:hover{background:#555}.preset-btn{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);border-radius:6px;padding:8px 12px;color:#ccc;font-size:11px;font-weight:500;cursor:pointer;transition:all .2s ease;text-align:center;white-space:nowrap;flex-shrink:0;min-width:fit-content}.preset-btn:hover{background:rgba(255,255,255,.15);border-color:rgba(255,255,255,.3);color:#fff}.preset-btn:active{background:rgba(110,195,244,.2);border-color:#6ec3f4;color:#6ec3f4}input[type=range].disabled{opacity:.5;cursor:not-allowed;pointer-events:none}.speed-value.disabled{opacity:.5;color:#666}.color-pickers{display:flex;justify-content:space-between;gap:8px;margin-top:8px}.color-picker-item{display:flex;flex-direction:column;align-items:center;gap:4px}.color-picker-item label{font-size:10px;color:#aaa;margin:0;text-align:center}.color-circle{width:32px;height:32px;border:2px solid rgba(255,255,255,.2);border-radius:50%;cursor:pointer;transition:all .2s ease;position:relative;overflow:hidden}.color-circle:hover{border-color:rgba(255,255,255,.4);transform:scale(1.05)}.color-circle input[type=color]{position:absolute;top:0;left:0;width:100%;height:100%;opacity:0;cursor:pointer}.color-circle input[type=color]:focus+.color-circle{border-color:#6ec3f4;box-shadow:0 0 0 2px rgba(110,195,244,.2)}.speed-control{display:flex;align-items:center;gap:8px;margin-top:8px}.control-icon-btn{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);border-radius:6px;width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;font-size:14px;flex-shrink:0}.control-icon-btn:hover{background:rgba(255,255,255,.15);border-color:rgba(255,255,255,.3);transform:scale(1.05)}.control-icon-btn:active{background:rgba(110,195,244,.2);border-color:#6ec3f4;transform:scale(.95)}.control-icon-btn.secondary{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.15)}.control-icon-btn.disabled{opacity:.4;cursor:not-allowed;pointer-events:none;transform:none}.speed-control input[type=range]{flex:1;height:6px;border-radius:3px;background:#444;outline:0;cursor:pointer}.speed-control input[type=range]::-webkit-slider-thumb{appearance:none;width:18px;height:18px;border-radius:50%;background:#6ec3f4;cursor:pointer;border:2px solid #222;transition:background .2s}.speed-control input[type=range]::-webkit-slider-thumb:hover{background:#5ba8d4}.speed-control input[type=range]::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:#6ec3f4;cursor:pointer;border:2px solid #222}#speed-value{font-size:12px;color:#6ec3f4;font-weight:500;min-width:32px;text-align:right}.palette-scroll{display:flex;gap:12px;overflow-x:auto;padding:8px 0;scrollbar-width:thin;scrollbar-color:#444 transparent}.palette-scroll::-webkit-scrollbar{height:4px}.palette-scroll::-webkit-scrollbar-track{background:0 0}.palette-scroll::-webkit-scrollbar-thumb{background:#444;border-radius:2px}.palette-item{display:flex;flex-direction:column;align-items:center;gap:6px;cursor:pointer;padding:8px;border-radius:8px;transition:all .2s ease;min-width:60px}.palette-item:hover{background:rgba(255,255,255,.1);transform:translateY(-2px)}.palette-item.selected{background:rgba(110,195,244,.2);border:1px solid #6ec3f4;transform:translateY(-2px)}.palette-item.selected .palette-name{color:#6ec3f4;font-weight:600}.palette-colors{display:flex;gap:2px;border-radius:4px;overflow:hidden;border:1px solid rgba(255,255,255,.2)}.palette-color{width:12px;height:20px}.palette-name{font-size:10px;color:#ccc;text-align:center;font-weight:500}@media (max-width:480px){.controls{width:250px;max-width:280px;right:-90vw;border-radius:12px 0 0 12px;padding:16px 16px 126px 16px;top:10px}.controls-toggle.active{right:210px}.controls header{margin-bottom:16px}.controls h1{font-size:18px;margin:16px 0 6px 0}.controls .subtitle{font-size:13px;margin-bottom:16px}.color-pickers{gap:12px}.color-circle{width:36px;height:36px}.palette-scroll{gap:8px}.palette-item{min-width:60px}.palette-colors{width:60px;height:32px}.palette-color{height:32px}.speed-control{gap:8px;flex-direction:column}.speed-control input[type=range]{width:100%}#speed-value{min-width:35px;font-size:12px}.control-icon-btn{width:36px;height:36px;font-size:14px}.dimension-row{flex-direction:column;gap:12px}.dimension-item{width:100%}.dimension-item label{font-size:12px}.dimension-item input,.dimension-item select{padding:8px;font-size:14px}.preset-scroll{gap:8px}.preset-btn{padding:8px 12px;font-size:11px;min-width:100px}.btn.primary-cta{padding:12px 20px;font-size:14px;width:100%}.shader-select,input[type=number],input[type=range]{font-size:14px}.shader-select{padding:10px;background-position:right 8px center}}@media (max-width:360px){.controls{padding:12px 12px 126px 12px}.controls h1{font-size:16px}.color-circle{width:32px;height:32px}.palette-item{min-width:50px}.palette-colors{width:50px;height:28px}.palette-color{height:28px}.preset-btn{min-width:90px;font-size:10px;padding:6px 10px}}@media (max-height:500px) and (orientation:landscape){.controls{height:100vh;overflow-y:auto;padding:12px}.controls h1{font-size:16px;margin:8px 0 4px 0}.controls .subtitle{font-size:11px;margin-bottom:8px}.control-group{margin-bottom:12px}.controls header{margin-bottom:12px}}@media (hover:none) and (pointer:coarse){.color-circle{min-width:40px;min-height:40px}.palette-item{min-height:40px;cursor:pointer}.preset-btn{min-height:40px;cursor:pointer}.control-icon-btn{min-width:44px;min-height:44px;cursor:pointer}.color-pickers{gap:16px}.palette-scroll{gap:12px}.speed-control{gap:12px}.controls{-webkit-touch-callout:none;-webkit-user-select:none;-khtml-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}input,select,textarea{-webkit-user-select:text;-moz-user-select:text;-ms-user-select:text;user-select:text}}#follow-btn,#share-btn{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);color:#fff;font-size:16px;font-weight:500;padding:14px 24px;display:flex;align-items:center;justify-content:center}#follow-btn:hover,#share-btn:hover{background:rgba(255,255,255,.15);border-color:rgba(255,255,255,.3);transform:translateY(-1px);box-shadow:0 4px 12px rgba(255,255,255,.1)}#follow-btn:active,#share-btn:active{transform:translateY(0);box-shadow:0 2px 8px rgba(255,255,255,.15)}#follow-btn:disabled,#share-btn:disabled{opacity:.7;cursor:default}@media (max-width:480px){.button-group{flex-direction:column;gap:8px}#follow-btn,#share-btn{font-size:14px;padding:12px 20px;width:100%}}.share-modal-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:rgba(0,0,0,.8);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:10000;animation:fadeIn .2s ease-out}.share-modal{background:rgba(20,20,20,.95);backdrop-filter:blur(20px);border-radius:16px;border:1px solid rgba(255,255,255,.1);padding:0;max-width:400px;width:90%;max-height:90vh;overflow:hidden;animation:slideUp .3s ease-out}.share-modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid rgba(255,255,255,.1)}.share-modal-header h3{margin:0;color:#fff;font-size:18px;font-weight:600}.share-modal-close{background:0 0;border:none;color:#fff;font-size:24px;cursor:pointer;padding:4px;line-height:1;opacity:.7;transition:opacity .2s}.share-modal-close:hover{opacity:1}.share-modal-content{padding:24px}.share-toggle-section{margin-bottom:24px;padding-bottom:20px;border-bottom:1px solid rgba(255,255,255,.1)}.share-toggle-options{display:flex;gap:12px}.share-toggle-option{display:flex;align-items:flex-start;gap:12px;cursor:pointer;padding:12px;border-radius:8px;border:1px solid rgba(255,255,255,.1);background:rgba(255,255,255,.02);transition:all .2s;flex:1}.share-toggle-option:hover{background:rgba(255,255,255,.05);border-color:rgba(255,255,255,.2)}.share-toggle-option input[type=radio]{width:16px;height:16px;margin:2px 0 0 0;cursor:pointer;accent-color:#6ec3f4}.share-toggle-label{display:flex;flex-direction:column;gap:4px;flex:1}.share-toggle-title{color:#fff;font-size:14px;font-weight:600;line-height:1.3}.share-toggle-desc{color:rgba(255,255,255,.7);font-size:12px;line-height:1.4}.share-options{display:grid;grid-template-columns:1fr 1fr;gap:12px}.share-option{display:flex;align-items:center;gap:12px;padding:14px 16px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:8px;color:#fff;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;text-decoration:none}.share-option:hover{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.2);transform:translateY(-1px)}.share-option:active{transform:translateY(0)}.share-option svg{flex-shrink:0;opacity:.8}.share-toast{position:fixed;bottom:20px;left:50%;transform:translateX(-50%) translateY(100px);background:rgba(20,20,20,.95);backdrop-filter:blur(10px);color:#fff;padding:12px 20px;border-radius:8px;border:1px solid rgba(255,255,255,.1);font-size:14px;font-weight:500;z-index:10001;opacity:0;transition:all .3s ease-out}.share-toast.show{opacity:1;transform:translateX(-50%) translateY(0)}@keyframes fadeIn{from{opacity:0}to{opacity:1}}@keyframes slideUp{from{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}@media (max-width:480px){.share-modal{width:95%;margin:20px}.share-modal-header{padding:16px 20px}.share-modal-content{padding:20px}.share-options{grid-template-columns:1fr 1fr;gap:10px}.share-option{padding:12px 14px}.share-toggle-options{flex-direction:column}}