*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{width:100%;height:100%}body{color:#e2e8f0;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#1a1a1a;font-family:Inter,Segoe UI,system-ui,-apple-system,sans-serif;overflow-x:hidden}.navbar{z-index:100;background:#222;border-bottom:1px solid #ffffff0f;justify-content:space-between;align-items:center;height:48px;padding:0 24px;display:flex}.navbar-left{align-items:center;gap:10px;display:flex}.navbar-logo{color:#fff;letter-spacing:1px;background:linear-gradient(135deg,#ff8c00,#ffa01e);border-radius:6px;justify-content:center;align-items:center;width:30px;height:30px;font-size:13px;font-weight:800;display:inline-flex}.navbar-title{color:#ffa01e;font-size:16px;font-weight:700}.navbar-center{position:absolute;left:50%;transform:translate(-50%)}.mode-switch{background:#ffffff08;border:1px solid #ffffff1a;border-radius:6px;display:flex;overflow:hidden}.mode-btn{color:#ffffff59;cursor:pointer;background:0 0;border:none;padding:5px 16px;font-size:12px;font-weight:600;transition:all .2s}.mode-btn.active{color:#ffa01e;background:#ffa01e33}.mode-btn:hover:not(.active){color:#fff9;background:#ffffff0d}.navbar-right{gap:8px;display:flex}.navbar-btn{color:#fff6;cursor:not-allowed;background:0 0;border:1px solid #ffffff1a;border-radius:6px;padding:5px 14px;font-size:12px}.uploader-section{margin-bottom:20px}.section-label{color:#ffffff80;text-transform:uppercase;letter-spacing:1px;margin-bottom:10px;font-size:13px;font-weight:600}.drop-zone{text-align:center;cursor:pointer;color:#ffffff59;border:2px dashed #ffa01e4d;border-radius:10px;padding:32px 16px;transition:all .3s}.drop-zone:hover,.drop-zone.drag-over{color:#ffffffb3;background:#ffa01e0f;border-color:#ffa01e}.drop-icon{color:#ffa01e;margin-bottom:8px;font-size:36px;line-height:1}.drop-zone p{margin:0;font-size:14px}.preview-wrap{border:1px solid #ffffff14;border-radius:10px;position:relative;overflow:hidden}.preview-img{object-fit:contain;background:#111;width:100%;max-height:220px;display:block}.clear-btn{color:#fff;cursor:pointer;background:#ef4444cc;border:none;border-radius:6px;padding:4px 12px;font-size:12px;position:absolute;top:8px;right:8px}.clear-btn:hover{background:#ef4444}.params-section{flex-direction:column;gap:16px;display:flex}.param-group{flex-direction:column;gap:6px;display:flex}.param-label{color:#ffffff73;text-transform:uppercase;letter-spacing:.5px;font-size:12px}.res-btns{gap:6px;display:flex}.res-btn{color:#ffffff80;cursor:pointer;background:#ffffff08;border:1px solid #ffffff1a;border-radius:6px;flex:1;padding:8px 0;font-size:14px;font-weight:600;transition:all .2s}.res-btn:hover{color:#fff;border-color:#ffa01e66}.res-btn.active{color:#ffa01e;background:#ffa01e26;border-color:#ffa01e;box-shadow:0 0 8px #ffa01e26}.param-select{color:#fff;background:#2a2a2a;border:1px solid #ffffff1a;border-radius:6px;outline:none;padding:8px 12px;font-size:14px}.param-select:focus{border-color:#ffa01e}.param-select option{background:#2a2a2a}.toggle-btn{color:#ffffff73;cursor:pointer;text-align:left;background:0 0;border:1px solid #ffffff14;border-radius:6px;padding:6px 12px;font-size:13px}.toggle-btn:hover{color:#fffc}.api-settings{background:#ffffff05;border:1px solid #ffffff0f;border-radius:8px;flex-direction:column;gap:6px;padding:12px;display:flex}.param-input{color:#fff;background:#2a2a2a;border:1px solid #ffffff1a;border-radius:6px;outline:none;padding:8px 12px;font-size:14px}.param-input:focus{border-color:#ffa01e}.generate-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#ff8c00,#ffa01e);border:none;border-radius:8px;margin-top:8px;padding:14px 0;font-size:16px;font-weight:700;transition:all .3s;position:relative;overflow:hidden;box-shadow:0 0 16px #ff8c0040}.generate-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 0 24px #ff8c0066}.generate-btn:disabled{opacity:.4;cursor:not-allowed}.generate-btn.generating{animation:1.5s ease-in-out infinite pulse-glow}@keyframes pulse-glow{0%,to{box-shadow:0 0 16px #ff8c0040}50%{box-shadow:0 0 32px #ff8c0080}}.gen-loading{align-items:center;gap:8px;display:inline-flex}.lightbox-overlay{z-index:1000;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);cursor:zoom-out;background:#000000d9;justify-content:center;align-items:center;animation:.2s lb-fade-in;display:flex;position:fixed;inset:0}@keyframes lb-fade-in{0%{opacity:0}to{opacity:1}}.lightbox-img{object-fit:contain;cursor:default;border-radius:8px;max-width:90vw;max-height:90vh;box-shadow:0 0 40px #7c3aed4d,0 0 80px #06b6d426}.lightbox-close{color:#ffffffb3;cursor:pointer;background:#0a0e1ab3;border:1px solid #fff3;border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;font-size:20px;transition:all .2s;display:flex;position:absolute;top:20px;right:24px}.lightbox-close:hover{color:#fff;background:#7c3aed66}.result-view{background:#1e1e1e99;border:1px solid #ffffff0f;border-radius:10px;flex:1;justify-content:center;align-items:center;min-height:300px;display:flex;overflow:hidden}.result-loading{text-align:center;color:#ffffff80}.loading-ring{border:3px solid #ffa01e;border-color:#ffa01e #ff8c00 #ffa01e26 #ffa01e26;border-radius:50%;width:56px;height:56px;margin:0 auto 16px;animation:1s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.result-loading p{font-size:14px}.result-error{text-align:center;color:#ef4444;padding:24px;font-size:14px}.result-content{flex-direction:column;align-items:center;gap:16px;width:100%;padding:16px;display:flex}.result-img{object-fit:contain;border-radius:8px;max-width:100%;max-height:50vh}.result-img.clickable{cursor:zoom-in;transition:box-shadow .2s}.result-img.clickable:hover{box-shadow:0 0 12px #ffa01e33}.download-btn{color:#ffa01e;cursor:pointer;background:#ffa01e1a;border:1px solid #ffa01e4d;border-radius:8px;padding:10px 28px;font-size:14px;font-weight:600;transition:all .2s}.download-btn:hover{background:#ffa01e33;box-shadow:0 0 12px #ffa01e33}.result-empty{text-align:center;color:#fff3}.empty-icon{margin-bottom:12px}.result-empty p{font-size:14px}.history-panel{padding:0 24px 24px}.history-empty{color:#fff3;text-align:center;padding:16px 0;font-size:14px}.history-grid{gap:12px;padding-bottom:8px;display:flex;overflow-x:auto}.history-grid::-webkit-scrollbar{height:4px}.history-grid::-webkit-scrollbar-thumb{background:#ffa01e40;border-radius:2px}.history-item{cursor:pointer;background:#ffffff05;border:1px solid #ffffff0f;border-radius:8px;flex-shrink:0;align-items:center;gap:6px;padding:8px;transition:all .2s;display:flex}.history-item:hover{border-color:#ffa01e4d;box-shadow:0 0 8px #ffa01e1a}.history-thumb{object-fit:cover;background:#111;border-radius:6px;width:64px;height:64px}.history-thumb.clickable{cursor:zoom-in;transition:box-shadow .2s}.history-thumb.clickable:hover{box-shadow:0 0 8px #ffa01e4d}.history-arrow{color:#ffffff40;font-size:16px}.preview-page{background:#1a1a1a;flex:1;width:100%;min-height:0;display:flex}.preview-sidebar{background:#222;border-right:1px solid #ffffff0f;flex-direction:column;flex-shrink:0;width:280px;display:flex;overflow-y:auto}.preview-sidebar::-webkit-scrollbar{width:4px}.preview-sidebar::-webkit-scrollbar-thumb{background:#ffa01e4d;border-radius:2px}.preview-sidebar::-webkit-scrollbar-track{background:0 0}.heightmap-upload{cursor:pointer;text-align:center;border-bottom:1px solid #ffffff0f;padding:14px 16px;transition:background .2s}.heightmap-upload:hover{background:#ffa01e0d}.heightmap-thumb{object-fit:contain;border:1px solid #ffffff14;border-radius:6px;max-width:100%;max-height:160px}.upload-placeholder{color:#ffffff40;flex-direction:column;align-items:center;gap:6px;padding:20px 0;display:flex}.upload-placeholder svg{opacity:.35;color:#ffa01e}.upload-placeholder span{font-size:12px}.upload-hint{color:#ffffff26!important;font-size:11px!important}.ctrl-section{border-bottom:1px solid #ffffff0f;padding:12px 16px}.colormap-upload{cursor:pointer;text-align:center;border-bottom:1px solid #ffffff0f;padding:10px 16px;transition:background .2s}.colormap-upload:hover{background:#ffa01e0d}.colormap-clear{color:#f87171;cursor:pointer;background:#ef44441a;border:1px solid #ef44444d;border-radius:4px;margin-top:6px;padding:2px 12px;font-size:11px;transition:all .2s;display:inline-block}.colormap-clear:hover{background:#ef444433}.ctrl-section-title{text-transform:uppercase;letter-spacing:1px;color:#ffffff4d;margin-bottom:10px;font-size:11px;font-weight:600}.ctrl-section-title.ctrl-section-toggle{cursor:pointer;-webkit-user-select:none;user-select:none;justify-content:space-between;align-items:center;transition:color .2s;display:flex}.ctrl-section-title.ctrl-section-toggle:hover{color:#ffffff80}.ctrl-section-arrow{color:#ffffff40;font-size:10px;transition:transform .2s}.ctrl-section-arrow.collapsed{transform:rotate(-90deg)}.model-selector{flex-wrap:wrap;gap:4px;display:flex}.model-chip{color:#fff6;cursor:pointer;background:0 0;border:1px solid #ffa01e33;border-radius:4px;padding:5px 12px;font-size:11px;transition:all .2s}.model-chip.active{color:#ffa01e;background:#ffa01e33;border-color:#ffa01e}.model-chip:hover:not(.active){color:#fff9;background:#ffa01e14}.ctrl-row{align-items:center;gap:8px;margin-bottom:8px;display:flex}.ctrl-row:last-child{margin-bottom:0}.ctrl-label{color:#ffffff73;flex-shrink:0;min-width:56px;font-size:12px}.ctrl-slider{-webkit-appearance:none;background:#ffffff14;border-radius:2px;outline:none;flex:1;height:3px;transition:background .15s}.ctrl-slider:hover{background:#ffffff1f}.ctrl-slider::-webkit-slider-thumb{-webkit-appearance:none;cursor:pointer;background:#ffa01e;border-radius:50%;width:12px;height:12px;transition:box-shadow .15s;box-shadow:0 0 4px #ffa01e66}.ctrl-slider::-webkit-slider-thumb:hover{box-shadow:0 0 8px #ffa01e99}.ctrl-value{color:#ffffff59;text-align:right;font-variant-numeric:tabular-nums;min-width:32px;font-size:11px}.ctrl-toggle{cursor:pointer;color:#ffffff80;align-items:center;gap:8px;margin-bottom:6px;font-size:12px;display:flex}.ctrl-toggle:last-child{margin-bottom:0}.ctrl-toggle input[type=checkbox]{accent-color:#ffa01e}.preview-main{flex-direction:column;flex:1;min-width:0;min-height:0;display:flex}.preview-viewport{flex:1;min-width:0;min-height:0;position:relative;overflow:hidden}.preview-viewport canvas{display:block;width:100%!important;height:100%!important}.heightmap-upload.drag-over,.colormap-upload.drag-over{background:#ffa01e1a;border-color:#ffa01e}.preview-history-bar{background:#222;border-top:1px solid #ffffff14;flex-direction:column;flex-shrink:0;height:290px;padding:8px 12px;display:flex}.preview-history-bar-list{flex-wrap:wrap;flex:1;align-content:flex-start;gap:10px;min-height:0;padding-right:4px;display:flex;overflow-y:auto}.preview-history-bar-list::-webkit-scrollbar{width:3px}.preview-history-bar-list::-webkit-scrollbar-thumb{background:#ffa01e33;border-radius:2px}.preview-history-bar-item{background:#ffffff08;border:1px solid #ffffff0f;border-radius:6px;flex-shrink:0;align-items:center;gap:4px;padding:4px;transition:border-color .15s;display:flex}.preview-history-bar-item:hover{border-color:#ffa01e40}.preview-history-bar-thumb{object-fit:cover;cursor:grab;background:#111;border-radius:4px;width:120px;height:120px;transition:box-shadow .15s}.preview-history-bar-thumb:active{cursor:grabbing}.preview-history-bar-thumb:hover{box-shadow:0 0 6px #ffa01e4d}.preview-history-bar-arrow{color:#ffffff26;flex-shrink:0;font-size:14px}.ctrl-export-btns{gap:8px;margin-top:8px;display:flex}.ctrl-export-btn{color:#ffa01e;cursor:pointer;background:#ffa01e14;border:1px solid #ffa01e4d;border-radius:6px;flex:1;padding:8px 0;font-size:13px;transition:all .2s}.ctrl-export-btn:hover:not(:disabled){background:#ffa01e2e;border-color:#ffa01e80}.ctrl-export-btn:disabled{opacity:.3;cursor:not-allowed}body:before{content:"";pointer-events:none;z-index:0;background:radial-gradient(at 30% 20%,#ffa01e0a 0%,#0000 50%),radial-gradient(at 70% 80%,#ff780008 0%,#0000 50%);width:200%;height:200%;position:fixed;top:-50%;left:-50%}.app{z-index:1;flex-direction:column;height:100vh;display:flex;position:relative}.main-layout{flex:1;gap:20px;padding:20px 24px;display:flex;overflow:hidden}.left-panel{flex-direction:column;flex-shrink:0;gap:4px;width:340px;padding-right:4px;display:flex;overflow-y:auto}.left-panel::-webkit-scrollbar{width:4px}.left-panel::-webkit-scrollbar-thumb{background:#ffa01e4d;border-radius:2px}.right-panel{flex:1;min-width:0;display:flex}.bottom-panel{border-top:1px solid #ffffff0f;flex-shrink:0;padding-top:16px}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#ffa01e33;border-radius:3px}
