:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}html,#root{width:100%;height:100%}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;min-width:320px;min-height:100vh;width:100%;height:100%}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.app{width:100%;margin:0;padding:0;min-height:100vh;display:flex;flex-direction:column;overflow-x:hidden;box-sizing:border-box}@media (max-width: 768px){.app{padding:0}}.texmateria-header{background:#fff;border-bottom:1px solid rgba(0,0,0,.1);position:sticky;top:0;z-index:100;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2}.texmateria-header .header-container{max-width:1200px;margin:0 auto;padding:0 2rem;height:60px;display:flex;align-items:center;justify-content:space-between;position:relative}.texmateria-header .logo{text-decoration:none;color:#667eea;display:flex;align-items:center;gap:.75rem;z-index:101}.texmateria-header .logo-image{height:40px;width:auto}.texmateria-header .logo h1{font-size:1.5rem;font-weight:700;margin:0}.texmateria-header .menu-toggle{display:none;flex-direction:column;gap:4px;background:none;border:none;cursor:pointer;padding:8px;z-index:101}.texmateria-header .menu-toggle span{display:block;width:24px;height:3px;background:#667eea;border-radius:2px;transition:all .3s ease}.texmateria-header .main-nav{display:flex;gap:2rem}.texmateria-header .main-nav a{color:#333;text-decoration:none;font-weight:500;transition:color .2s ease;position:relative}.texmateria-header .main-nav a:hover{color:#667eea}.texmateria-header .main-nav a:after{content:"";position:absolute;bottom:-4px;left:0;width:0;height:2px;background:#667eea;transition:width .2s ease}.texmateria-header .main-nav a:hover:after{width:100%}@media (max-width: 768px){.texmateria-header .header-container{padding:0 1rem}.texmateria-header .logo h1{font-size:1.25rem}.texmateria-header .logo-image{height:32px}.texmateria-header .menu-toggle{display:flex}.texmateria-header .main-nav{position:absolute;top:60px;right:0;width:200px;background:#fff;border-left:1px solid rgba(0,0,0,.1);border-bottom:1px solid rgba(0,0,0,.1);box-shadow:-2px 2px 8px #0000001a;flex-direction:column;gap:0;padding:0;opacity:0;visibility:hidden;transform:translateY(-10px);transition:all .3s ease}.texmateria-header .main-nav.active{opacity:1;visibility:visible;transform:translateY(0)}.texmateria-header .main-nav a{padding:1rem 1.5rem;border-bottom:1px solid rgba(0,0,0,.05)}.texmateria-header .main-nav a:last-child{border-bottom:none}.texmateria-header .main-nav a:after{display:none}}@media (max-width: 480px){.texmateria-header .header-container{padding:0 .75rem}.texmateria-header .logo h1{font-size:1.1rem}.texmateria-header .logo-image{height:28px}.texmateria-header .logo{gap:.5rem}}.texmateria-footer{background:#2d3748;color:#cbd5e0;margin-top:auto}.footer-container{max-width:1200px;margin:0 auto;padding:2rem;text-align:center}.footer-links{display:flex;gap:1rem;justify-content:center;align-items:center;margin-bottom:1rem}.footer-links a,.footer-link-button{color:#cbd5e0;text-decoration:none;transition:color .2s ease;background:none;border:none;cursor:pointer;font-size:inherit;font-family:inherit;padding:0}.footer-links a:hover,.footer-link-button:hover{color:#667eea}.separator{color:#4a5568}.footer-copyright{font-size:.9rem;opacity:.8}.footer-copyright p{margin:0}@media (max-width: 768px){.footer-container{padding:1.5rem 1rem}.footer-links{font-size:.9rem;gap:.5rem}.footer-copyright{font-size:.8rem}}.image-upload{background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:15px;border-radius:8px;box-shadow:0 4px 16px #0000001a}.image-upload h3{margin:0 0 10px;font-size:.9rem;font-weight:600;color:#333}.image-upload-area{border:2px dashed #667eea;border-radius:6px;padding:20px 15px;text-align:center;cursor:pointer;transition:all .3s ease;background:#667eea0d}.image-upload-area:hover{border-color:#5a6fd8;background:#667eea1a;transform:translateY(-2px);box-shadow:0 4px 12px #667eea33}.image-upload-area.dragging{border-color:#5a6fd8;background:#667eea26;transform:scale(1.02);box-shadow:0 6px 16px #667eea4d}.upload-icon{font-size:2.5rem;margin-bottom:10px;opacity:.7}.upload-text{margin-bottom:8px}.upload-text p{margin:4px 0;font-size:.9rem;color:#555;line-height:1.4}.upload-text strong{color:#667eea;font-weight:600}.upload-hint{font-size:.75rem;color:#888;font-style:italic}.parameter-panel{background:#fff;border-radius:8px;padding:15px;box-shadow:0 2px 4px #0000001a}.panel-header h3{color:#667eea;margin:0 0 12px;font-size:16px;font-weight:600;border-bottom:2px solid #667eea;padding-bottom:8px}.param-group{margin-bottom:15px}.param-group label{display:flex;flex-direction:column;gap:6px}.param-label{color:#34495e;font-size:13px;font-weight:600}.param-label strong{color:#667eea;font-size:14px}.param-group input[type=range]{width:100%;height:6px;border-radius:3px;background:#e0e0e0;outline:none;-webkit-appearance:none}.param-group input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:20px;height:20px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);cursor:pointer;box-shadow:0 2px 4px #0003}.param-group input[type=range]::-moz-range-thumb{width:20px;height:20px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);cursor:pointer;border:none;box-shadow:0 2px 4px #0003}.param-group input[type=range]:disabled{opacity:.5;cursor:not-allowed}.param-hint{font-size:11px;color:#7f8c8d;font-style:italic}.checkbox-label{flex-direction:row!important;align-items:center;gap:8px!important;cursor:pointer}.checkbox-label input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:#667eea}.checkbox-label span{color:#34495e;font-weight:600;font-size:13px}.param-group select{width:100%;padding:8px 12px;margin-top:4px;border:2px solid #e0e0e0;border-radius:6px;background:#fff;color:#34495e;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s ease;outline:none}.param-group select:hover:not(:disabled){border-color:#667eea}.param-group select:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.param-group select:disabled{opacity:.5;cursor:not-allowed;background:#f5f5f5}.action-section{margin:15px 0;text-align:center}.generate-button{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:12px 20px;border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:600;transition:all .2s ease;box-shadow:0 2px 4px #667eea4d;width:100%}.generate-button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 8px #667eea66}.generate-button:disabled{background:#95a5a6;cursor:not-allowed;transform:none;box-shadow:none}.info-section{background:#f8f9fa;padding:12px;border-radius:6px;margin-top:15px}.info-section h4{color:#667eea;margin:0 0 8px;font-size:13px;font-weight:600}.info-section p{color:#555;line-height:1.5;margin:0 0 8px;font-size:11px}.info-section ul{list-style:none;padding:0;margin:0}.info-section ul li{padding:4px 0;color:#555;font-size:11px}@media (max-width: 768px){.parameter-panel{padding:12px}.panel-header h3{font-size:15px}.generate-button{font-size:13px;padding:10px 15px}}.preview-panel{background:#fff;border-radius:8px;padding:15px;box-shadow:0 2px 4px #0000001a;display:flex;flex-direction:column;gap:12px}.preview-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.preview-header-left{flex:1}.preview-header-right{display:flex;gap:8px;align-items:center}.diffuse-toggle{display:flex;align-items:center;gap:6px;cursor:pointer;font-size:13px;font-weight:600;color:#34495e}.diffuse-toggle input[type=checkbox]{width:16px;height:16px;cursor:pointer;accent-color:#667eea}.preview-header h3{color:#667eea;margin:0 0 4px;font-size:16px;font-weight:600}.preview-hint{color:#7f8c8d;font-size:11px;margin:0}.preview-container{width:100%;height:500px;background:linear-gradient(45deg,#eee 25%,transparent 25%),linear-gradient(-45deg,#eee 25%,transparent 25%),linear-gradient(45deg,transparent 75%,#eee 75%),linear-gradient(-45deg,transparent 75%,#eee 75%);background-size:20px 20px;background-position:0 0,0 10px,10px -10px,-10px 0px;background-color:#fff;border-radius:8px;overflow:hidden;position:relative;display:flex;align-items:center;justify-content:center}.processing-overlay{position:absolute;inset:0;background:linear-gradient(135deg,#667eeaf2,#764ba2f2);display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:10;gap:12px}.processing-emojis{position:relative;width:400px;height:150px;margin-bottom:20px}.processing-emoji{position:absolute;font-size:2.5rem}.emoji-1{left:10%;top:40%;animation:bounce 1.2s ease-in-out infinite}.emoji-2{left:28%;top:40%;animation:bounce 1.4s ease-in-out infinite}.emoji-3{left:46%;top:40%;animation:bounce 1.1s ease-in-out infinite}.emoji-4{left:64%;top:40%;animation:bounce 1.3s ease-in-out infinite}.emoji-5{left:82%;top:40%;animation:bounce 1.5s ease-in-out infinite}.processing-text{color:#fff;font-size:16px;font-weight:600;position:relative;z-index:1}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-20px)}}.preview-container canvas{display:block;width:100%;height:100%}.preview-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;height:500px;color:#7f8c8d;transition:all .3s ease}.preview-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;color:#7f8c8d}.preview-empty .empty-icon{font-size:4rem;margin-bottom:1rem}.preview-empty h3{color:#34495e;margin:0 0 .5rem;font-size:1.3rem}.preview-empty p{color:#7f8c8d;margin:0}.preview-placeholder:hover{background:#667eea0d;transform:translateY(-2px)}.empty-icon{font-size:4rem;margin-bottom:1rem}.preview-placeholder h3{color:#34495e;margin:0 0 .5rem;font-size:1.3rem}.preview-placeholder p{color:#7f8c8d;margin:0}.preview-info{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;padding:1rem;background:#f8f9fa;border-radius:8px}.info-item{display:flex;justify-content:space-between;align-items:center}.info-label{color:#7f8c8d;font-weight:500}.info-value{color:#34495e;font-weight:600}.download-section{display:flex;gap:12px;align-items:center;justify-content:center}.normal-map-preview{flex-shrink:0}.normal-map-preview img{width:200px;height:200px;object-fit:contain;border-radius:6px;border:2px solid #e0e0e0;box-shadow:0 2px 6px #0000001a;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;pointer-events:none}.geometry-select{background:#fff;border:2px solid #e0e0e0;border-radius:6px;padding:8px 10px;font-size:13px;font-weight:600;color:#34495e;cursor:pointer;transition:all .2s ease;min-width:110px}.geometry-select:hover{border-color:#667eea}.geometry-select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.download-button{background:linear-gradient(135deg,#27ae60,#219a52);color:#fff;padding:10px 20px;border:none;border-radius:6px;cursor:pointer;font-size:13px;font-weight:600;transition:all .2s ease;box-shadow:0 2px 4px #27ae604d}.download-button:hover{transform:translateY(-1px);box-shadow:0 4px 8px #27ae6066}.download-menu{position:absolute;top:100%;left:0;right:0;margin-top:4px;background:#fff;border:2px solid #e0e0e0;border-radius:6px;box-shadow:0 4px 12px #0000001a;overflow:hidden;z-index:100}.download-menu-item{width:100%;padding:10px 15px;border:none;background:#fff;color:#34495e;font-size:13px;font-weight:600;cursor:pointer;text-align:left;transition:background .2s ease}.download-menu-item:hover{background:#f0f2ff;color:#667eea}.download-menu-item:not(:last-child){border-bottom:1px solid #e0e0e0}@media (max-width: 768px){.preview-panel{padding:1.5rem}.preview-container{height:300px}.preview-info{grid-template-columns:1fr}.download-button{font-size:1rem;padding:.875rem 1.5rem}}.language-switcher{display:flex;align-items:center;margin-left:auto}.language-dropdown{background:#ffffff4d;border:1px solid rgba(255,255,255,.5);border-radius:6px;padding:6px 12px;font-size:12px;font-weight:600;color:#fff;cursor:pointer;transition:all .2s ease;min-width:120px;text-shadow:0 1px 2px rgba(0,0,0,.3)}.language-dropdown:hover{background:#fff6;border-color:#fff9}.language-dropdown:focus{outline:none;background:#ffffff80;border-color:#ffffffb3;box-shadow:0 2px 8px #0003}.language-dropdown option{background:#fff;color:#333;padding:8px 12px;font-size:12px;font-weight:500}@media (max-width: 768px){.language-dropdown{padding:5px 10px;font-size:11px;min-width:110px}}@media (max-width: 480px){.language-dropdown{min-width:100px;font-size:10px;padding:4px 8px}}.normal-maker{min-height:100vh;width:100%;background:linear-gradient(135deg,#667eea,#764ba2);padding:15px;box-sizing:border-box;margin:0;display:flex;flex-direction:column;overflow-x:hidden}.header{margin-bottom:15px;color:#fff}.header-content{display:flex;justify-content:space-between;align-items:center;max-width:1200px;margin:0 auto;width:100%}.header-text{text-align:left}.header h1{font-size:2rem;font-weight:600;margin:0 0 5px;text-shadow:0 2px 4px rgba(0,0,0,.3)}.subtitle{font-size:1rem;opacity:.9;margin:0}.content{display:grid;grid-template-columns:350px 1fr;gap:12px;width:100%;max-width:100%;margin:0;flex:1;box-sizing:border-box;overflow:hidden}.left-panel{display:flex;flex-direction:column;gap:12px;width:100%;box-sizing:border-box}.right-panel{background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:8px;box-shadow:0 4px 16px #0000001a;width:100%;min-width:0;overflow:hidden;box-sizing:border-box}@media (max-width: 1024px){.normal-maker{padding:10px}.content{grid-template-columns:1fr;gap:10px}.left-panel{order:2}.right-panel{order:1}}@media (max-width: 768px){.normal-maker{padding:10px}.header h1{font-size:1.5rem}.subtitle{font-size:.9rem}}.qa-section{margin:2rem 15px 0;padding:2.5rem;background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:12px;box-shadow:0 8px 32px #0000001f;border:1px solid rgba(255,255,255,.3)}.qa-section h2{background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-size:1.8rem;margin:0 0 2rem;font-weight:700;letter-spacing:-.02em}.qa-list{display:flex;flex-direction:column;gap:0}.qa-item{border-bottom:1px solid rgba(102,126,234,.1);transition:all .3s cubic-bezier(.4,0,.2,1);border-radius:8px;margin:0 -1.5rem;padding:1.75rem 1.5rem 1.75rem 3rem}.qa-item:last-child{border-bottom:none}.qa-item:hover{background:linear-gradient(90deg,#667eea0d,#764ba20d);transform:translate(8px);border-bottom-color:#667eea33}.qa-question{color:#1f2937;font-size:1.1rem;font-weight:600;margin-bottom:.75rem;display:flex;align-items:center;gap:.5rem}.qa-question:before{content:"💡";font-size:1.2rem;flex-shrink:0}.qa-item:nth-child(2) .qa-question:before{content:"🎯"}.qa-item:nth-child(3) .qa-question:before{content:"🌈"}.qa-answer{color:#6b7280;font-size:1rem;line-height:1.7;padding-left:2rem}@media (max-width: 768px){.qa-section{padding:1.5rem;margin:1rem auto 0}.qa-section h2{font-size:1.2rem}.qa-question{font-size:.9rem}.qa-answer{font-size:.85rem}}
